-
Notifications
You must be signed in to change notification settings - Fork 0
/
deployment.yml
100 lines (100 loc) · 2.13 KB
/
deployment.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
apiVersion: v1
kind: ConfigMap
metadata:
name: svn-configmap
data:
AuthLDAPBindDN: "uid=example,dc=example,dc=com"
AuthLDAPBindPassword: "strong_password"
AuthLDAPURL: "ldap://your.ldap.server:389/ou=people,dc=example,dc=com?uid?sub?(objectClass=*)"
LdapGroup: "cn=group_of_allowed_to_modify_users,ou=groups,dc=example,dc=com"
---
apiVersion: v1
kind: PersistentVolume
metadata:
name: storage-svn-data
labels:
type: local
spec:
storageClassName: manual
capacity:
storage: 100Gi
accessModes:
- ReadWriteOnce
hostPath:
path: "/srv/svn/data"
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: storage-svn-data
spec:
storageClassName: manual
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 100Gi
---
apiVersion: v1
kind: Service
metadata:
name: svn
labels:
app: svn
spec:
type: LoadBalancer
externalTrafficPolicy: Local
ports:
- port: 80
targetPort: 80
protocol: TCP
name: http
selector:
app: svn
---
apiVersion: apps/v1
kind: Deployment
metadata:
name: svn
labels:
app: svn
spec:
revisionHistoryLimit: 3 # removes old replicasets for deployment rollbacks
strategy:
rollingUpdate:
maxUnavailable: 0 # Avoid Terminating and ContainerCreating at the same time
selector:
matchLabels:
app: svn
template:
metadata:
labels:
app: svn
spec:
nodeSelector:
svn-data: "true"
containers:
- name: svn
image: mikolaw/svnldap:latest
imagePullPolicy: Always
envFrom:
- configMapRef:
name: svn-configmap
ports:
- containerPort: 80
livenessProbe:
tcpSocket:
port: 80
periodSeconds: 60
securityContext:
allowPrivilegeEscalation: false
privileged: false
readOnlyRootFilesystem: false
runAsNonRoot: false
volumeMounts:
- mountPath: /opt
name: svn-data
volumes:
- name: svn-data
persistentVolumeClaim:
claimName: storage-svn-data