测试环境k8s部署

测试环境k8s部署

测试环境k8s部署

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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
apiVersion: v1 
kind: ReplicationController
metadata:
name: redis-master
labels:
name: redis-master
spec:
replicas: 1
selector:
name: redis-master
template:
metadata:
labels:
name: redis-master
spec:
containers:
- name: redis-master
image: 192.168.106.117/library/redis:3.2.9
ports:
- containerPort: 6379
volumeMounts:
- name: redis-config-pvc
mountPath: "/usr/local/etc/redis/"
command: ["redis-server","/usr/local/etc/redis/redis-master.conf"]
volumes:
- name: redis-config-pvc
persistentVolumeClaim:
claimName: redis-config-pvc
--------
apiVersion: v1
kind: Service
metadata:
name: redis-master
labels:
name: redis-master
spec:
ports:
- port: 6379
targetPort: 6379
selector:
name: redis-master
--------------------
apiVersion: v1
kind: Pod
metadata:
labels:
name: busybox-test-dns
role: master
name: busybox
spec:
containers:
- name: busybox
image: 192.168.106.117/library/busybox:latest
command:
- sleep
- "3600"







---------------------

apiVersion: v1
kind: ReplicationController
metadata:
name: redis-slave
labels:
name: redis-slave
spec:
replicas: 1
selector:
name: redis-slave
template:
metadata:
labels:
name: redis-slave
spec:
containers:
- name: redis-slave
image: 192.168.106.117/library/redis:3.2.9
command: ["redis-server","/usr/local/etc/redis/redis-slave.conf"]
ports:
- containerPort: 6379
volumeMounts:
- name: redis-config-pvc
mountPath: "/usr/local/etc/redis/"
volumes:
- name: redis-config-pvc
persistentVolumeClaim:
claimName: redis-config-pvc


-------------------------------

apiVersion: v1
kind: Service
metadata:
name: redis-slave
labels:
name: redis-slave
spec:
ports:
- port: 6379
targetPort: 6379
selector:
name: redis-slave

----------------------------------------------
# 创建redis-config-pvc存放redis config文件

#master
port 6379
bind 0.0.0.0
#daemonize yes
masterauth "123456"
requirepass "123456"
timeout 0
rdbcompression yes
dbfilename "redis.rdb"
dir "/data"
maxmemory 50gb
maxmemory-policy noeviction
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit slave 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
notify-keyspace-events "gxE"


#slave
port 6379
bind 0.0.0.0
logfile "redis6500.log"
pidfile "6500.pid"
masterauth "123456"
requirepass "123456"
slave-read-only yes
slave-priority 100
timeout 0
rdbcompression yes
dbfilename "redis.rdb"
dir "/data"
maxmemory 50gb
maxmemory-policy noeviction
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit slave 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
slaveof redis-master 6379


#sentinel
port 6379
protected-mode no
dir "/data"
sentinel myid bf64f29ff9578fb293d5d90ec85d083e2ae03725
sentinel monitor mymaster redis-master 6379 1
sentinel down-after-milliseconds mymaster 5000
sentinel failover-timeout mymaster 18000
sentinel auth-pass mymaster 123456
sentinel config-epoch mymaster 8735
sentinel leader-epoch mymaster 8735
sentinel known-slave mymaster redis-slave 6379
sentinel current-epoch 8735


----------------------------------

apiVersion: v1
kind: ReplicationController
metadata:
name: redis-sentinel
labels:
name: redis-sentinel
spec:
replicas: 1
selector:
name: redis-sentinel
template:
metadata:
labels:
name: redis-sentinel
spec:
containers:
- name: redis-sentinel
image: 192.168.106.117/library/redis:3.2.9
command: ["redis-sentinel","/usr/local/etc/redis/sentinel.conf"]
ports:
- containerPort: 6379
volumeMounts:
- name: redis-config-pvc
mountPath: "/usr/local/etc/redis/"
volumes:
- name: redis-config-pvc
persistentVolumeClaim:
claimName: redis-config-pvc


-------------------------------

apiVersion: v1
kind: Service
metadata:
name: redis-sentinel
labels:
name: redis-sentinel
spec:
ports:
- port: 6379
targetPort: 6379
selector:
name: redis-sentinel

----------------------------------------------


创建tomcat 的 pvc



----------------------------------

apiVersion: v1
kind: ReplicationController
metadata:
name: tomcat-infoverisystem
labels:
name: tomcat-infoverisystem
spec:
replicas: 1
selector:
name: tomcat-infoverisystem
template:
metadata:
labels:
name: tomcat-infoverisystem
spec:
containers:
- name: tomcat-infoverisystem
image: 192.168.106.117/library/tomcat:8.5.35
ports:
- containerPort: 8080
volumeMounts:
- name: tomcat-war-pvc
mountPath: "/usr/local/tomcat/webapps"
volumes:
- name: tomcat-war-pvc
persistentVolumeClaim:
claimName: tomcat-war-pvc


-------------------------------

apiVersion: v1
kind: Service
metadata:
name: tomcat-infoverisystem
labels:
name: tomcat-infoverisystem
spec:
ports:
- port: 8080
targetPort: 8080
selector:
name: tomcat-infoverisystem

----------------------------------------------

apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: tomcat-infoverisystem
annotations:
kubernets.io/ingress.class: "nginx"
spec:
rules:
- http:
paths:
- path:
backend:
serviceName: tomcat-infoverisystem
servicePort: 8080