Showing
1 changed file
with
167 additions
and
0 deletions
kubernetes/zookeeper.yaml
0 → 100644
1 | +apiVersion: v1 | ||
2 | +kind: Service | ||
3 | +metadata: | ||
4 | + name: zk-headless | ||
5 | + labels: | ||
6 | + app: zk-headless | ||
7 | +spec: | ||
8 | + ports: | ||
9 | + - port: 2888 | ||
10 | + name: server | ||
11 | + - port: 3888 | ||
12 | + name: leader-election | ||
13 | + clusterIP: None | ||
14 | + selector: | ||
15 | + app: zk | ||
16 | +--- | ||
17 | +apiVersion: v1 | ||
18 | +kind: ConfigMap | ||
19 | +metadata: | ||
20 | + name: zk-config | ||
21 | +data: | ||
22 | + ensemble: "zk-0;zk-1;zk-2" | ||
23 | + jvm.heap: "2G" | ||
24 | + tick: "2000" | ||
25 | + init: "10" | ||
26 | + sync: "5" | ||
27 | + client.cnxns: "60" | ||
28 | + snap.retain: "3" | ||
29 | + purge.interval: "1" | ||
30 | +--- | ||
31 | +apiVersion: policy/v1beta1 | ||
32 | +kind: PodDisruptionBudget | ||
33 | +metadata: | ||
34 | + name: zk-budget | ||
35 | +spec: | ||
36 | + selector: | ||
37 | + matchLabels: | ||
38 | + app: zk | ||
39 | + minAvailable: 2 | ||
40 | +--- | ||
41 | +apiVersion: apps/v1beta1 | ||
42 | +kind: StatefulSet | ||
43 | +metadata: | ||
44 | + name: zk | ||
45 | +spec: | ||
46 | + serviceName: zk-headless | ||
47 | + replicas: 3 | ||
48 | + template: | ||
49 | + metadata: | ||
50 | + labels: | ||
51 | + app: zk | ||
52 | + annotations: | ||
53 | + pod.alpha.kubernetes.io/initialized: "true" | ||
54 | + scheduler.alpha.kubernetes.io/affinity: > | ||
55 | + { | ||
56 | + "podAntiAffinity": { | ||
57 | + "requiredDuringSchedulingIgnoredDuringExecution": [ | ||
58 | + { | ||
59 | + "labelSelector": { | ||
60 | + "matchExpressions": [ | ||
61 | + { | ||
62 | + "key": "app", | ||
63 | + "operator": "In", | ||
64 | + "values": [ "zk-headless" ] | ||
65 | + } | ||
66 | + ] | ||
67 | + }, | ||
68 | + "topologyKey": "kubernetes.io/hostname" | ||
69 | + } | ||
70 | + ] | ||
71 | + } | ||
72 | + } | ||
73 | + spec: | ||
74 | + containers: | ||
75 | + - name: k8szk | ||
76 | + imagePullPolicy: Always | ||
77 | + image: gcr.io/google_samples/k8szk:v1 | ||
78 | + resources: | ||
79 | + requests: | ||
80 | + memory: "1Gi" | ||
81 | + cpu: "0.5" | ||
82 | + ports: | ||
83 | + - containerPort: 2181 | ||
84 | + name: client | ||
85 | + - containerPort: 2888 | ||
86 | + name: server | ||
87 | + - containerPort: 3888 | ||
88 | + name: leader-election | ||
89 | + env: | ||
90 | + - name : ZK_ENSEMBLE | ||
91 | + valueFrom: | ||
92 | + configMapKeyRef: | ||
93 | + name: zk-config | ||
94 | + key: ensemble | ||
95 | + - name : ZK_HEAP_SIZE | ||
96 | + valueFrom: | ||
97 | + configMapKeyRef: | ||
98 | + name: zk-config | ||
99 | + key: jvm.heap | ||
100 | + - name : ZK_TICK_TIME | ||
101 | + valueFrom: | ||
102 | + configMapKeyRef: | ||
103 | + name: zk-config | ||
104 | + key: tick | ||
105 | + - name : ZK_INIT_LIMIT | ||
106 | + valueFrom: | ||
107 | + configMapKeyRef: | ||
108 | + name: zk-config | ||
109 | + key: init | ||
110 | + - name : ZK_SYNC_LIMIT | ||
111 | + valueFrom: | ||
112 | + configMapKeyRef: | ||
113 | + name: zk-config | ||
114 | + key: tick | ||
115 | + - name : ZK_MAX_CLIENT_CNXNS | ||
116 | + valueFrom: | ||
117 | + configMapKeyRef: | ||
118 | + name: zk-config | ||
119 | + key: client.cnxns | ||
120 | + - name: ZK_SNAP_RETAIN_COUNT | ||
121 | + valueFrom: | ||
122 | + configMapKeyRef: | ||
123 | + name: zk-config | ||
124 | + key: snap.retain | ||
125 | + - name: ZK_PURGE_INTERVAL | ||
126 | + valueFrom: | ||
127 | + configMapKeyRef: | ||
128 | + name: zk-config | ||
129 | + key: purge.interval | ||
130 | + - name: ZK_CLIENT_PORT | ||
131 | + value: "2181" | ||
132 | + - name: ZK_SERVER_PORT | ||
133 | + value: "2888" | ||
134 | + - name: ZK_ELECTION_PORT | ||
135 | + value: "3888" | ||
136 | + command: | ||
137 | + - sh | ||
138 | + - -c | ||
139 | + - zkGenConfig.sh && zkServer.sh start-foreground | ||
140 | + readinessProbe: | ||
141 | + exec: | ||
142 | + command: | ||
143 | + - "zkOk.sh" | ||
144 | + initialDelaySeconds: 15 | ||
145 | + timeoutSeconds: 5 | ||
146 | + livenessProbe: | ||
147 | + exec: | ||
148 | + command: | ||
149 | + - "zkOk.sh" | ||
150 | + initialDelaySeconds: 15 | ||
151 | + timeoutSeconds: 5 | ||
152 | + volumeMounts: | ||
153 | + - name: datadir | ||
154 | + mountPath: /var/lib/zookeeper | ||
155 | + securityContext: | ||
156 | + runAsUser: 1000 | ||
157 | + fsGroup: 1000 | ||
158 | + volumeClaimTemplates: | ||
159 | + - metadata: | ||
160 | + name: datadir | ||
161 | + annotations: | ||
162 | + volume.alpha.kubernetes.io/storage-class: anything | ||
163 | + spec: | ||
164 | + accessModes: [ "ReadWriteOnce" ] | ||
165 | + resources: | ||
166 | + requests: | ||
167 | + storage: 20Gi |