创建App
创建yaml文件
[root@localhost ~]# vim nginx.yaml
apiVersion: v1
kind: ReplicationController
metadata:
name: my-nginx
spec:
replicas: 1
template:
metadata:
labels:
app: nginx
spec:
containers:
- name: nginx
image: nginx
resources:
limits:
memory: "128Mi"
cpu: "500m"
ports:
- containerPort: 80
启动nginx
[root@localhost ~]# kubectl create -f nginx.yaml
replicationcontroller "my-nginx" created
[root@localhost ~]# kubectl get pods
NAME READY STATUS RESTARTS AGE
my-nginx-lwr99 0/1 ContainerCreating 0 7s
查看日志
[root@localhost ~]# kubectl describe pod my-nginx-lwr99
Name: my-nginx-lwr99
Namespace: default
Node: 192.168.56.202/192.168.56.202
Start Time: Mon, 23 Apr 2018 14:24:57 +0800
Labels: app=nginx
Status: Running
IP: 172.30.55.2
Controllers: ReplicationController/my-nginx
Containers:
nginx:
Container ID: docker://4a01698fd122030de55c5b1caf42b256e28fe7264d32f97b4c89fdd0ab34f83d
Image: nginx
Image ID: docker-pullable://docker.io/nginx@sha256:18156dcd747677b03968621b2729d46021ce83a5bc15118e5bcced925fb4ebb9
Port: 80/TCP
Limits:
cpu: 500m
memory: 128Mi
Requests:
cpu: 500m
memory: 128Mi
State: Running
Started: Mon, 23 Apr 2018 14:25:18 +0800
Ready: True
Restart Count: 0
Volume Mounts:
Environment Variables:
Conditions:
Type Status
Initialized True
Ready True
PodScheduled True
No volumes.
QoS Class: Guaranteed
Tolerations:
Events:
FirstSeen LastSeen Count From SubObjectPath Type Reason Message
--------- -------- ----- ---- ------------- -------- ------ -------
54s 54s 1 {default-scheduler } Normal Scheduled Successfully assigned my-nginx-lwr99 to 192.168.56.202
50s 50s 1 {kubelet 192.168.56.202} spec.containers{nginx} Normal Pulling pulling image "nginx"
54s 34s 2 {kubelet 192.168.56.202} Warning MissingClusterDNS kubelet does not have ClusterDNS IP configured and cannot create Pod using "ClusterFirst" policy. Falling back to DNSDefault policy.
34s 34s 1 {kubelet 192.168.56.202} spec.containers{nginx} Normal Pulled Successfully pulled image "nginx"
34s 34s 1 {kubelet 192.168.56.202} spec.containers{nginx} Normal Created Created container with docker id 4a01698fd122; Security:[seccomp=unconfined]
33s 33s 1 {kubelet 192.168.56.202} spec.containers{nginx} Normal Started Started container with docker id 4a01698fd122
查看结果
[root@localhost ~]# kubectl get pods
NAME READY STATUS RESTARTS AGE
my-nginx-lwr99 1/1 Running 0 1m
在node上查看结果
[root@localhost ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
4a01698fd122 nginx "nginx -g 'daemon ..." 46 seconds ago Up 44 seconds k8s_nginx.cf5bec70_my-nginx-lwr99_default_0b2a62a8-46bf-11e8-94fc-000c29619eeb_2d98d52a
ce5d302bc2ed registry.access.redhat.com/rhel7/pod-infrastructure:latest "/usr/bin/pod" About a minute ago Up About a minute k8s_POD.a8590b41_my-nginx-lwr99_default_0b2a62a8-46bf-11e8-94fc-000c29619eeb_cf234267
动态添加配置
对于上面创建的app是一个,下面我们动态的再添加一个
执行命令:
kubectl scale replicationcontroller --replicas=2 my-nginx
[root@localhost ~]# kubectl scale replicationcontroller --replicas=2 my-nginx
replicationcontroller "my-nginx" scaled
[root@localhost ~]# kubectl get pods
NAME READY STATUS RESTARTS AGE
my-nginx-8m40c 0/1 ContainerCreating 0 12s
my-nginx-lwr99 1/1 Running 0 22m
[root@localhost ~]# kubectl get rc
NAME DESIRED CURRENT READY AGE
my-nginx 2 2 2 25m
查看结果
[root@localhost ~]# kubectl describe pod my-nginx
Name: my-nginx-8m40c
Namespace: default
Node: 192.168.56.201/192.168.56.201
Start Time: Mon, 23 Apr 2018 14:47:31 +0800
Labels: app=nginx
Status: Running
IP: 172.30.31.2
Controllers: ReplicationController/my-nginx
Containers:
nginx:
Container ID: docker://925085542d0d105693f72f4b4f727367aa8df69505e2424a90a19df27928bd09
Image: nginx
Image ID: docker-pullable://docker.io/nginx@sha256:18156dcd747677b03968621b2729d46021ce83a5bc15118e5bcced925fb4ebb9
Port: 80/TCP
Limits:
cpu: 500m
memory: 128Mi
Requests:
cpu: 500m
memory: 128Mi
State: Running
Started: Mon, 23 Apr 2018 14:47:50 +0800
Ready: True
Restart Count: 0
Volume Mounts:
Environment Variables:
Conditions:
Type Status
Initialized True
Ready True
PodScheduled True
No volumes.
QoS Class: Guaranteed
Tolerations:
Events:
FirstSeen LastSeen Count From SubObjectPath Type Reason Message
--------- -------- ----- ---- ------------- -------- ------ -------
12m 12m 1 {default-scheduler } Normal Scheduled Successfully assigned my-nginx-8m40c to 192.168.56.201
12m 12m 1 {kubelet 192.168.56.201} spec.containers{nginx} Normal Pulling pulling image "nginx"
12m 12m 2 {kubelet 192.168.56.201} Warning MissingClusterDNS kubelet does not have ClusterDNS IP configured and cannot create Pod using "ClusterFirst" policy. Falling back to DNSDefault policy.
12m 12m 1 {kubelet 192.168.56.201} spec.containers{nginx} Normal Pulled Successfully pulled image "nginx"
12m 12m 1 {kubelet 192.168.56.201} spec.containers{nginx} Normal Created Created container with docker id 925085542d0d; Security:[seccomp=unconfined]
12m 12m 1 {kubelet 192.168.56.201} spec.containers{nginx} Normal Started Started container with docker id 925085542d0d
Name: my-nginx-lwr99
Namespace: default
Node: 192.168.56.202/192.168.56.202
Start Time: Mon, 23 Apr 2018 14:24:57 +0800
Labels: app=nginx
Status: Running
IP: 172.30.55.2
Controllers: ReplicationController/my-nginx
Containers:
nginx:
Container ID: docker://4a01698fd122030de55c5b1caf42b256e28fe7264d32f97b4c89fdd0ab34f83d
Image: nginx
Image ID: docker-pullable://docker.io/nginx@sha256:18156dcd747677b03968621b2729d46021ce83a5bc15118e5bcced925fb4ebb9
Port: 80/TCP
Limits:
cpu: 500m
memory: 128Mi
Requests:
cpu: 500m
memory: 128Mi
State: Running
Started: Mon, 23 Apr 2018 14:25:18 +0800
Ready: True
Restart Count: 0
Volume Mounts:
Environment Variables:
Conditions:
Type Status
Initialized True
Ready True
PodScheduled True
No volumes.
QoS Class: Guaranteed
Tolerations:
Events:
FirstSeen LastSeen Count From SubObjectPath Type Reason Message
--------- -------- ----- ---- ------------- -------- ------ -------
35m 35m 1 {default-scheduler } Normal Scheduled Successfully assigned my-nginx-lwr99 to 192.168.56.202
35m 35m 1 {kubelet 192.168.56.202} spec.containers{nginx} Normal Pulling pulling image "nginx"
35m 35m 2 {kubelet 192.168.56.202} Warning MissingClusterDNS kubelet does not have ClusterDNS IP configured and cannot create Pod using "ClusterFirst" policy. Falling back to DNSDefault policy.
35m 35m 1 {kubelet 192.168.56.202} spec.containers{nginx} Normal Pulled Successfully pulled image "nginx"
35m 35m 1 {kubelet 192.168.56.202} spec.containers{nginx} Normal Created Created container with docker id 4a01698fd122; Security:[seccomp=unconfined]
35m 35m 1 {kubelet 192.168.56.202} spec.containers{nginx} Normal Started Started container with docker id 4a01698fd122
[root@localhost ~]#
Node节点删除
[root@localhost ~]# kubectl get node
NAME STATUS AGE
192.168.56.201 Ready 4d
192.168.56.202 Ready 4d
[root@localhost ~]# kubectl delete node 192.168.56.201
node "192.168.56.201" deleted
[root@localhost ~]# kubectl get node
NAME STATUS AGE
192.168.56.202 Ready 4d
从上面的执行命令结束后,发现现在k8s就只有一个节点了。但是我们发现服务器还是2个
[root@localhost ~]# kubectl get pods
NAME READY STATUS RESTARTS AGE
my-nginx-lwr99 1/1 Running 0 38m
my-nginx-wwv4j 1/1 Running 0 47s
再次describe发现ip端都是来自同一个网段,如下:
[root@localhost ~]# kubectl describe pod my-nginx
Name: my-nginx-lwr99
Namespace: default
Node: 192.168.56.202/192.168.56.202
Start Time: Mon, 23 Apr 2018 14:24:57 +0800
Labels: app=nginx
Status: Running
IP: 172.30.55.2
Controllers: ReplicationController/my-nginx
Containers:
nginx:
Container ID: docker://4a01698fd122030de55c5b1caf42b256e28fe7264d32f97b4c89fdd0ab34f83d
Image: nginx
Image ID: docker-pullable://docker.io/nginx@sha256:18156dcd747677b03968621b2729d46021ce83a5bc15118e5bcced925fb4ebb9
Port: 80/TCP
Limits:
cpu: 500m
memory: 128Mi
Requests:
cpu: 500m
memory: 128Mi
State: Running
Started: Mon, 23 Apr 2018 14:25:18 +0800
Ready: True
Restart Count: 0
Volume Mounts:
Environment Variables:
Conditions:
Type Status
Initialized True
Ready True
PodScheduled True
No volumes.
QoS Class: Guaranteed
Tolerations:
Events:
FirstSeen LastSeen Count From SubObjectPath Type Reason Message
--------- -------- ----- ---- ------------- -------- ------ -------
40m 40m 1 {default-scheduler } Normal Scheduled Successfully assigned my-nginx-lwr99 to 192.168.56.202
40m 40m 1 {kubelet 192.168.56.202} spec.containers{nginx} Normal Pulling pulling image "nginx"
40m 40m 2 {kubelet 192.168.56.202} Warning MissingClusterDNS kubelet does not have ClusterDNS IP configured and cannot create Pod using "ClusterFirst" policy. Falling back to DNSDefault policy.
40m 40m 1 {kubelet 192.168.56.202} spec.containers{nginx} Normal Pulled Successfully pulled image "nginx"
40m 40m 1 {kubelet 192.168.56.202} spec.containers{nginx} Normal Created Created container with docker id 4a01698fd122; Security:[seccomp=unconfined]
40m 40m 1 {kubelet 192.168.56.202} spec.containers{nginx} Normal Started Started container with docker id 4a01698fd122
Name: my-nginx-wwv4j
Namespace: default
Node: 192.168.56.202/192.168.56.202
Start Time: Mon, 23 Apr 2018 15:02:36 +0800
Labels: app=nginx
Status: Running
IP: 172.30.55.3
Controllers: ReplicationController/my-nginx
Containers:
nginx:
Container ID: docker://b3446831953f87524167b134e863be44d1d55093344df41bb2d8c11b4a348966
Image: nginx
Image ID: docker-pullable://docker.io/nginx@sha256:18156dcd747677b03968621b2729d46021ce83a5bc15118e5bcced925fb4ebb9
Port: 80/TCP
Limits:
cpu: 500m
memory: 128Mi
Requests:
cpu: 500m
memory: 128Mi
State: Running
Started: Mon, 23 Apr 2018 15:02:51 +0800
Ready: True
Restart Count: 0
Volume Mounts:
Environment Variables:
Conditions:
Type Status
Initialized True
Ready True
PodScheduled True
No volumes.
QoS Class: Guaranteed
Tolerations:
Events:
FirstSeen LastSeen Count From SubObjectPath Type Reason Message
--------- -------- ----- ---- ------------- -------- ------ -------
2m 2m 1 {default-scheduler } Normal Scheduled Successfully assigned my-nginx-wwv4j to 192.168.56.202
2m 2m 1 {kubelet 192.168.56.202} spec.containers{nginx} Normal Pulling pulling image "nginx"
2m 2m 2 {kubelet 192.168.56.202} Warning MissingClusterDNS kubelet does not have ClusterDNS IP configured and cannot create Pod using "ClusterFirst" policy. Falling back to DNSDefault policy.
2m 2m 1 {kubelet 192.168.56.202} spec.containers{nginx} Normal Pulled Successfully pulled image "nginx"
2m 2m 1 {kubelet 192.168.56.202} spec.containers{nginx} Normal Created Created container with docker id b3446831953f; Security:[seccomp=unconfined]
2m 2m 1 {kubelet 192.168.56.202} spec.containers{nginx} Normal Started Started container with docker id b3446831953f
[root@localhost ~]#
添加新的node
在刚刚删除的node上从新启动节点,执行下面的命令
[root@localhost ~]# systemctl start kubelet
[root@localhost ~]# systemctl restart kubelet
从M上查看结果
[root@localhost ~]# kubectl get node
NAME STATUS AGE
192.168.56.201 Ready 12s
192.168.56.202 Ready 4d
添加可以访问外网
上面的app是不可以访问外网的,如果想要访问外网需要创建一个service服务。
[root@localhost ~]# cat nginxsrc.yaml
apiVersion: v1
kind: Service
metadata:
name: nginx-service
spec:
externalIPs:
- 192.168.56.200
ports:
- port: 8000
targetPort: 80
protocol: TCP
selector:
app: nginx
https://www.58jb.com/html/180.html
https://www.cnblogs.com/junneyang/p/6274689.html