[root@centos7-docker-test1 ~]# kubectl get rcphp
CONTROLLER CONTAINER(S) IMAGE(S) SELECTOR REPLICAS AGEnode
centos7 centos7 centos:7 run=centos7 3 3hmysql
mysql mysql mysql:5.5 run=mysql 7 3hsql
tomcat tomcat tomcat:8.0 run=tomcat 5 22hdocker
[root@centos7-docker-test1 ~]# kubectl get poapache
NAME READY STATUS RESTARTS AGEcentos
centos7-asa0g 0/1 CrashLoopBackOff 45 3hapi
centos7-eow3g 0/1 CrashLoopBackOff 45 3htomcat
centos7-qmslb 0/1 CrashLoopBackOff 42 3happ
mysql-0a5tv 0/1 CrashLoopBackOff 45 3h
mysql-131lh 0/1 CrashLoopBackOff 45 3h
mysql-7cj2s 0/1 CrashLoopBackOff 46 3h
mysql-89h04 0/1 CrashLoopBackOff 46 3h
mysql-htu4u 0/1 CrashLoopBackOff 46 3h
mysql-khndm 0/1 CrashLoopBackOff 46 3h
mysql-uke1c 0/1 CrashLoopBackOff 46 3h
tomcat-1wwbn 1/1 Running 1 22h
tomcat-f83z1 1/1 Running 1 22h
tomcat-fu2qf 1/1 Running 1 22h
tomcat-l39ih 1/1 Running 1 22h
tomcat-o647v 1/1 Running 1 22h
[root@centos7-docker-test1 kubernetes]# kubectl get po -o wide
NAME READY STATUS RESTARTS AGE NODE
centos7-igbjl 0/1 CrashLoopBackOff 10 28m 10.1.1.169
centos7-jpoyx 0/1 CrashLoopBackOff 10 28m 10.1.1.169
centos7-thu24 0/1 CrashLoopBackOff 10 28m 10.1.1.171
mysql-0nxwk 0/1 CrashLoopBackOff 10 29m 10.1.1.171
mysql-47jvi 0/1 CrashLoopBackOff 10 29m 10.1.1.171
mysql-7ggtp 0/1 CrashLoopBackOff 10 29m 10.1.1.169
mysql-hoi4c 0/1 CrashLoopBackOff 10 29m 10.1.1.169
mysql-md9ir 0/1 CrashLoopBackOff 10 29m 10.1.1.171
mysql-v0y6b 0/1 CrashLoopBackOff 10 29m 10.1.1.169
mysql-x7lh1 0/1 CrashLoopBackOff 10 29m 10.1.1.169
rc-tomcat8-2-0xxs6 1/1 Running 0 8m 10.1.1.171
rc-tomcat8-2-1l4iy 1/1 Running 0 17m 10.1.1.169
rc-tomcat8-2-igirv 1/1 Running 0 13m 10.1.1.169
rc-tomcat8-2-ih5bb 1/1 Running 0 18m 10.1.1.171
rc-tomcat8-2-qklgd 1/1 Running 0 15m 10.1.1.171
tomcat-1wwbn 1/1 Running 1 23h 10.1.1.169
tomcat-f83z1 1/1 Running 1 23h 10.1.1.171
tomcat-fu2qf 1/1 Running 1 23h 10.1.1.171
tomcat-l39ih 1/1 Running 1 23h 10.1.1.169
tomcat-o647v 1/1 Running 1 23h 10.1.1.169
[root@centos7-docker-test1 ~]# kubectl get namespace
NAME LABELS STATUS AGE
default <none> Active 23h
[root@centos7-docker-test1 ~]# kubectl get nodes
NAME LABELS STATUS AGE
10.1.1.169 kubernetes.io/hostname=10.1.1.169 Ready 22h
10.1.1.171 kubernetes.io/hostname=10.1.1.171 Ready 23h
製做yaml格式的pod 複製控制文件:
[root@centos7-docker-test1 kubernetes]# more rc-tomcat.yaml
apiVersion: v1
kind: ReplicationController
metadata:
name: rc-tomcat8-1
spec:
replicas: 4
template:
metadata:
labels:
app: tomcat8-1
spec:
containers:
- name: tomcat8-1
p_w_picpath: tomcat:8.0
ports:
- containerPort: 8080
[root@centos7-docker-test1 kubernetes]# kubectl create -f rc-tomcat.yaml
可使用rolling-update更新部署且正在運行的業務,每次起一個新的pod,而後刪除一箇舊的,直到替換掉全部的pod。更新內容爲不一樣的name,version,label才能夠進行。也能夠中斷更新,使用-rollback回滾
可使用scale進行副本數量的擴大和縮小
kubectl scale rc rc-tomcat8-2 --replicas=5
可使用autoscale進行副本的自動擴展和縮小,有待驗證
實例:啓動多個apache容器副本:
[root@centos7-docker-test1 kubernetes]# more apache.yaml
apiVersion: v1
kind: ReplicationController
metadata:
name: my-apache
labels:
app: my-apache
spec:
replicas: 2
selector:
app: my-apache
template:
metadata:
labels:
app: my-apache
spec:
containers:
- name: my-apache
p_w_picpath: index.alauda.cn/tutum/apache-php:latest
ports:
- containerPort: 80
[root@centos7-docker-test1 kubernetes]# more apache-svc.yaml
apiVersion: v1
kind: Service
metadata:
name: my-apache
labels:
app: my-apache
spec:
type: NodePort
ports:
- port: 80
targetPort: 80
nodePort: 30066
selector:
app: my-apache