目录

  • 一、Pod清单的简述
  • 二、实验环境的检测
  • 三、创建Pod清单
  • 四、Pod中创建多容器
  • 五、对于有些镜像,需要在清单中添加一个bash
  • 六、标签的相关用法

 

一、Pod资源清单的简述

Pod清单时将Pod要实现的操和命令全部放进一个文件中,通过应用文件中的内容来完成 相应的部署等

Pod 模板是包含在其他对象中的 Pod 规范,例如 Replication Controllers、 Jobs 和 DaemonSets。 控制器使用 Pod 模板来制作实际使用的 Pod。 下面的示例是一个简单的 Pod 清单,它包含一个打印消息的容器。

apiVersion: v1
kind: Pod
metadata:
  name: myapp-pod
  labels:
    app: myapp
spec:
  containers:
  - name: myapp-container
    image: busybox
    command: ['sh', '-c', 'echo Hello Kubernetes! && sleep 3600']

Pod 模板就像饼干切割器,而不是指定所有副本的当前期望状态。 一旦饼干被切掉,饼干就与切割器没有关系。 没有“量子纠缠”。 随后对模板的更改或甚至切换到新的模板对已经创建的 Pod 没有直接影响。 类似地,由副本控制器创建的 Pod 随后可以被直接更新。 这与 Pod 形成有意的对比,Pod 指定了属于 Pod 的所有容器的当前期望状态。 这种方法从根本上简化了系统语义,增加了原语的灵活性。

接下来实验步骤:

 

二、实验环境的检测

  • 1.查看集群的状态
  • 2.清理实验环境

 

1、查看集群的状态

1.1、在用普通用户完成相关的实验

开始实验时要把集群集起来所以要进行以下的操作

[root@server1 ~]# su - kubeadm                        ##进入普通用户
Last login: lun feb 24 11:31:25 EST 2020 on pts/0
[kubeadm@server1 ~]$
[kubeadm@server1 ~]$
[kubeadm@server1 ~]$ kubectl get cs                   ##查看cs是否正常工作
NAME                 STATUS    MESSAGE             ERROR
scheduler            Healthy   ok                  
controller-manager   Healthy   ok                  
etcd-0               Healthy   {"health":"true"}   
[kubeadm@server1 ~]$
[kubeadm@server1 ~]$

k8s创建一个deployment的 时序图_Pod

 

 

1.2、查看集群的工作是否正常

[kubeadm@server1 ~]$ kubectl get nodes                   ##查看各个节点是否正常的运行 
NAME      STATUS   ROLES    AGE   VERSION
server1   Ready    master   45h   v1.17.3
server3   Ready    <none>   45h   v1.17.3
server4   Ready    <none>   45h   v1.17.3

[kubeadm@server1 ~]$ kubectl get pod -n kube-system      ##查看个服务是否正常的开启
NAME                              READY   STATUS    RESTARTS   AGE
coredns-9d85f5447-9p6b8           0/1     Running   2          5h57m
coredns-9d85f5447-nxwch           1/1     Running   2          76m
etcd-server1                      1/1     Running   10         45h
kube-apiserver-server1            1/1     Running   17         45h
kube-controller-manager-server1   1/1     Running   25         45h
kube-flannel-ds-amd64-h6mpc       1/1     Running   4          40h
kube-flannel-ds-amd64-h8k92       1/1     Running   5          40h
kube-flannel-ds-amd64-w4ws4       1/1     Running   3          40h
kube-proxy-8hc7t                  1/1     Running   3          45h
kube-proxy-ktxlp                  1/1     Running   3          45h
kube-proxy-w9jxm                  1/1     Running   2          45h
kube-scheduler-server1            1/1     Running   24         45h

k8s创建一个deployment的 时序图_nginx_02

 

 

1.3、yaml 文件相当是pod的控制器  所以删除掉副本之后有重新生副本

[kubeadm@server1 ~]$ kubectl get pod
NAME                     READY   STATUS    RESTARTS   AGE
nginx-6db489d4b7-5pph4   1/1     Running   2          14h
nginx-6db489d4b7-gzr7z   1/1     Running   2          78m
nginx-6db489d4b7-jvjnf   1/1     Running   2          78m
[kubeadm@server1 ~]$
[kubeadm@server1 ~]$
[kubeadm@server1 ~]$ kubectl delete pod nginx-6db489d4b7-5pph4
pod "nginx-6db489d4b7-5pph4" deleted

\
[kubeadm@server1 ~]$                             ##删除后又重新生成
[kubeadm@server1 ~]$ kubectl get pod
NAME                     READY   STATUS    RESTARTS   AGE
nginx-6db489d4b7-5pph4   1/1     Running   2          14h
nginx-6db489d4b7-gzr7z   1/1     Running   2          78m
nginx-6db489d4b7-jvjnf   1/1     Running   2          78m
[kubeadm@server1 ~]$

k8s创建一个deployment的 时序图_bash_03

 

1.4、查看资源清单

[kubeadm@server1 ~]$ kubectl get pod -o yaml     ##查看资源清单
[kubeadm@server1 ~]$

k8s创建一个deployment的 时序图_bash_04

 

 

 

2、清理实验环境

[kubeadm@server1 ~]$ kubectl get deployments.app         ##删除管理文件信息 
NAME    READY   UP-TO-DATE   AVAILABLE   AGE
nginx   3/3     3            3           20h
[kubeadm@server1 ~]$
[kubeadm@server1 ~]$ kubectl delete deployments.apps nginx
deployment.apps "nginx" deleted
[kubeadm@server1 ~]$
[kubeadm@server1 ~]$ kubectl get deployments.[kubeadm@server1 ~]$ 删除掉之前的^C
app
No resources found in default namespace.

k8s创建一个deployment的 时序图_Pod_05

 

 

2.2、删除之前实验暴露的端口信息

[kubeadm@server1 ~]$ kubectl get svc           ##查看之前service控制器对外暴露的端口 
NAME         TYPE        CLUSTER-IP    EXTERNAL-IP   PORT(S)        AGE
kubernetes   ClusterIP   10.96.0.1     <none>        443/TCP        45h
nginx        NodePort    10.96.9.159   <none>        80:31641/TCP   17h
[kubeadm@server1 ~]$
[kubeadm@server1 ~]$ kubectl delete svc         ##删除掉端口暴露的信息 
error: resource(s) were provided, but no name, label selector, or --all flag specified
[kubeadm@server1 ~]$
[kubeadm@server1 ~]$ kubectl delete svc nginx     ##删除端口暴露的镜像信息
service "nginx" deleted
[kubeadm@server1 ~]$
[kubeadm@server1 ~]$
[kubeadm@server1 ~]$ kubectl get svc
NAME         TYPE        CLUSTER-IP   EXTERNAL-IP   PORT(S)   AGE
kubernetes   ClusterIP   10.96.0.1    <none>        443/TCP   45h
[kubeadm@server1 ~]$
[kubeadm@server1 ~]$

k8s创建一个deployment的 时序图_bash_06

 

 

三、创建Pod清单

  • 1.查看创建清单的配置信息
  • 2.创建Pod清单
  • 3.副本的删除

1、查看创建清单的配置信息

1.1、查看版本信息

[kubeadm@server1 ~]$ kubectl api-versions     ##版本的 查询命令

[kubeadm@server1 ~]$ kubectl explain pod      ##查看帮助文档

k8s创建一个deployment的 时序图_bash_07

 

1.2、查看帮助文档

k8s创建一个deployment的 时序图_Pod_08

 

1.2、查看资源清单的配置方法

[kubeadm@server1 ~]$ kubectl explain pod        ##查看资源清单的配置方法
KIND:     Pod
VERSION:  v1

DESCRIPTION:
     Pod is a collection of containers that can run on a host. This resource is
     created by clients and scheduled onto hosts.

FIELDS:
   apiVersion    <string>
     APIVersion defines the versioned schema of this representation of an
     object. Servers should convert recognized schemas to the latest internal
     value, and may reject unrecognized values. More info:
     https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources

   kind    <string>
     Kind is a string value representing the REST resource this object
     represents. Servers may infer this from the endpoint the client submits
     requests to. Cannot be updated. In CamelCase. More info:
     https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds

   metadata    <Object>
     Standard object's metadata. More info:
     https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#metadata

   spec    <Object>
     Specification of the desired behavior of the pod. More info:
     https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status

   status    <Object>
     Most recently observed status of the pod. This data may not be up to date.
     Populated by the system. Read-only. More info:
     https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#spec-and-status

k8s创建一个deployment的 时序图_nginx_09

 

1.3、后边有-required- 表示必须要加 是一定要加的参数

[kubeadm@server1 ~]$ kubectl explain pod.spec | less
 containers   <[]Object> -required-                        ## 后边有-required- 表示必须要加
     List of containers belonging to the pod. Containers cannot currently be
     added or removed. There must be at least one container in a Pod. Cannot be
     updated.

[kubeadm@server1 ~]$ kubectl explain pod.spec.containers

k8s创建一个deployment的 时序图_bash_10

 

 

2、创建Pod清单

2.1创建一个简单的yaml文件

[kubeadm@server1 ~]$ cat pod.yaml          
apiVersion: v1                          ##版本为v1
kind: Pod                               ##类型为pod
metadata:                               ##数据卷的名称
  name: demo
  labels:
    app: demo                           ##标签的名称 
spec:
  containers:
  - name: demo                          ##pod的名称 
    image: nginx                        ##镜像

k8s创建一个deployment的 时序图_nginx_11

 

2.2、测试:

[kubeadm@server1 ~]$ kubectl create -f pod.yaml       ##建立资源清单
pod/demo created
[kubeadm@server1 ~]$

k8s创建一个deployment的 时序图_bash_12

 

 

2.3查看副本的运行情况 、日志等

[kubeadm@server1 ~]$ kubectl get pod               ##查看副本的运行情况
NAME   READY   STATUS    RESTARTS   AGE
demo   1/1     Running   0          99s
[kubeadm@server1 ~]$
[kubeadm@server1 ~]$ kubectl describe pod demo     ##查看日志

k8s创建一个deployment的 时序图_nginx_13

k8s创建一个deployment的 时序图_nginx_14

 

 

3、副本的删除

原先有控制器的时候 删除副本会自动生成新的副本   现在时自定义的yaml文件 删除之后不能自动生成新的副本

[kubeadm@server1 ~]$ kubectl delete pod demo
pod "demo" deleted
[kubeadm@server1 ~]$
[kubeadm@server1 ~]$
[kubeadm@server1 ~]$ kubectl get pod
No resources found in default namespace.
[kubeadm@server1 ~]$

k8s创建一个deployment的 时序图_nginx_15

 

 

 

四、Pod中创建多容器

  • 1.发生资源争抢的情况(镜像使用的端口不同)
  • 2,.多镜像的创建

1、发生资源争抢的情况

1.1、容器监听相同端口会出现资源争抢的情况

一个pod中可以起多个容器    但是一个pod中共享网络资源 如果所有资源都监听一个端口  会发生资源争抢的情况

apiVersion: v1               ##版本
kind: Pod                    ##类型 
metadata:                    ##数据卷 
  name: demo                 ##数据卷的名称 
  labels:                    ##标签
    app: demo
spec:
  containers:                ##pod的名称 
  - name: vm1
    image: nginx             
  - name: vm2
    image: nginx             ##vm1、vm2都用同样的镜像来模拟端口资源争抢的情况

k8s创建一个deployment的 时序图_Pod_16

 

 1.2、测试:

[kubeadm@server1 ~]$ kubectl get pod            ##查看副本的运行情况
NAME   READY   STATUS   RESTARTS   AGE
demo   1/2     Error    1          12s          ##出现报错只有一个pod能够正常启动 
[kubeadm@server1 ~]$


[kubeadm@server1 ~]$ kubcetl get pod -o wide    ##查看资源配置的详细信息

k8s创建一个deployment的 时序图_nginx_17

 

 

1.3、查看日志

k8s创建一个deployment的 时序图_Pod_18

k8s创建一个deployment的 时序图_nginx_19

(发生了资源争抢的情况)

 

1.4、查看vm2日志

[kubeadm@server1 ~]$ kubectl logs demo -c vm2     ##查看vm2的日志

k8s创建一个deployment的 时序图_Pod_20

 

 

2、两个不同的镜像

1.1、修改yaml文件

k8s创建一个deployment的 时序图_nginx_21

apiVersion: v1              ##版本
kind: Pod                   ##类型
metadata:                   ##数据卷
  name: demo                ##标签
  labels:
    app: demo
spec:
  containers:
  - name: vm1
    image: nginx
  - name: vm2
    image: redis           ##一个pod里可以取多个容器

 

1.2、查看日志:

k8s创建一个deployment的 时序图_bash_22

k8s创建一个deployment的 时序图_nginx_23

 

1.3、查看详细的分配信息

k8s创建一个deployment的 时序图_Pod_24

 

 

五、对于有些镜像,需要在清单中添加一个bash

对于不能运行的镜像例如busybox是一个交互式的用户不能直接的运行需要在文件 中添加 bash

  • 1.没有添加bash
  • 2.添加bash

1、没有在文件中添加bash

k8s创建一个deployment的 时序图_Pod_25

k8s创建一个deployment的 时序图_nginx_26

 

1.2、测试:

k8s创建一个deployment的 时序图_nginx_27

 

2、添加一个bash

apiVersion: v1              ##版本
kind: Pod                   ##类型
metadata:                   ##数据卷
  name: demo                ##标签
  labels:
    app: demo
spec:
  containers:
  - name: vm1
    image: nginx
  - name: vm2
    image: redis             ##一个pod里可以取多个容器
  - name: vm3
    image: busybox                                
    command:                 ##命令
    - /bin/sh                ##执行命令
    - -c                     
    - sleep 300              ##持续300s,然后退出

k8s创建一个deployment的 时序图_nginx_28

k8s创建一个deployment的 时序图_Pod_29

 

2.1、测试:

[kubeadm@server1 ~]$
[kubeadm@server1 ~]$ kubectl create -f pod.yaml
pod/demo created
[kubeadm@server1 ~]$ kubectl get pod                     ##查看副本的运行情况
NAME   READY   STATUS    RESTARTS   AGE
demo   3/3     Running   0          29s

k8s创建一个deployment的 时序图_bash_30

2.2、查看日志:

查看日志:
Events:
  Type    Reason     Age        From               Message
  ----    ------     ----       ----               -------
  Normal  Scheduled  <unknown>  default-scheduler  Successfully assigned default/demo to server4
  Normal  Pulling    52s        kubelet, server4   Pulling image "nginx"
  Normal  Pulled     51s        kubelet, server4   Successfully pulled image "nginx"
  Normal  Created    50s        kubelet, server4   Created container vm1
  Normal  Started    49s        kubelet, server4   Started container vm1
  Normal  Pulling    49s        kubelet, server4   Pulling image "redis"
  Normal  Pulled     49s        kubelet, server4   Successfully pulled image "redis"
  Normal  Created    46s        kubelet, server4   Created container vm2
  Normal  Started    45s        kubelet, server4   Started container vm2
  Normal  Pulling    45s        kubelet, server4   Pulling image "busybox"
  Normal  Pulled     45s        kubelet, server4   Successfully pulled image "busybox"
  Normal  Created    44s        kubelet, server4   Created container vm3
  Normal  Started    43s        kubelet, server4   Started container vm3
[kubeadm@server1 ~]$

 

六、标签的相关用法

标签是k8s集群选择操作对象的一个中要因素

  • 1.查看标签
  • 2.打标签
  • 3.修改标签
  • 4.把标签放到固定的节点上
  • 5.在清单中增加标签选择器

1、查看标签的命令

[kubeadm@server1 ~]$ kubectl get pod --show-labels       ##查看pod的标签

[kubeadm@server1 ~]$ kubectl get pod -l app              ##查看节点的标签

[kubeadm@server1 ~]$ kubectl get pod -L app

 

2、打标签

[kubeadm@server1 ~]$ kubectl label pod demo version=v1      ##给pod打标签 

[kubeadm@server1 ~]$ kubectl get pod -L version             ##查看标签的命令
NAME   READY   STATUS    RESTARTS   AGE     VERSION
demo   3/3     Running   0          4m59s   v1

[kubeadm@server1 ~]$ kubectl get pod -n kube-system --show-labels    ##查看节点的标签

k8s创建一个deployment的 时序图_bash_31

(app 是 key demo是值)

k8s创建一个deployment的 时序图_bash_32

 

3、修改标签

[kubeadm@server1 ~]$ kubectl label pod demo app=nginx --overwrite      ## 修改标签 
pod/demo labeled
[kubeadm@server1 ~]$
[kubeadm@server1 ~]$ kubectl get pod --show-labels                      ##查看修改后标签的值
NAME   READY   STATUS    RESTARTS   AGE   LABELS
demo   2/3     Running   11         74m   app=nginx,version=v1
[kubeadm@server1 ~]$

k8s创建一个deployment的 时序图_nginx_33

 

3.2、测试

k8s创建一个deployment的 时序图_Pod_34

 

 

4、把标签放到固定的节点上

[kubeadm@server1 ~]$ kubectl label nodes server3 disktype=ssd    ##把标签放到server3的节点上
node/server3 labeled
[kubeadm@server1 ~]$ kubectl get node --show-labels               
                                                                 ##查看节点的标签信息 
NAME      STATUS   ROLES    AGE    VERSION   LABELS
server1   Ready    master   2d1h   v1.17.3   beta.kubernetes.io/arch=amd64,beta.kubernetes.io/os=linux,kubernetes.io/arch=amd64,kubernetes.io/hostname=server1,kubernetes.io/os=linux,node-role.kubernetes.io/master=
server3   Ready    <none>   2d1h   v1.17.3   beta.kubernetes.io/arch=amd64,beta.kubernetes.io/os=linux,disktype=ssd,kubernetes.io/arch=amd64,kubernetes.io/hostname=server3,kubernetes.io/os=linux
server4   Ready    <none>   2d1h   v1.17.3   beta.kubernetes.io/arch=amd64,beta.kubernetes.io/os=linux,kubernetes.io/arch=amd64,kubernetes.io/hostname=server4,kubernetes.io/os=linux
[kubeadm@server1 ~]$
[kubeadm@server1 ~]$ kubectl get node -l disktype                ##查看disktype标签在节点上
NAME      STATUS   ROLES    AGE    VERSION
server3   Ready    <none>   2d1h   v1.17.3
[kubeadm@server1 ~]$
[kubeadm@server1 ~]$

k8s创建一个deployment的 时序图_nginx_35

 

4.1、测试:

k8s创建一个deployment的 时序图_Pod_36



4.2、在server3中生成容器

[root@server3 ~]# docker ps
CONTAINER ID        IMAGE                                               COMMAND                  CREATED                  STATUS                  PORTS               NAMES
152d0d71eff4        ff281650a721                                        "/opt/bin/flanneld -…"   Less than a second ago   Up Less than a second                       k8s_kube-flannel_kube-flannel-ds-amd64-w4ws4_kube-system_8c0ee785-9440-4a69-9132-2d56130a5f5e_3
0678447c8d4d        ae853e93800d                                        "/usr/local/bin/kube…"   Less than a second ago   Up Less than a second                       k8s_kube-proxy_kube-proxy-w9jxm_kube-system_b2e2556d-2cc3-4194-8a72-61cc8c89bd00_2
73afa35e4faa        registry.aliyuncs.com/google_containers/pause:3.1   "/pause"                 Less than a second ago   Up Less than a second                       k8s_POD_kube-flannel-ds-amd64-w4ws4_kube-system_8c0ee785-9440-4a69-9132-2d56130a5f5e_2
75e05fef822d        registry.aliyuncs.com/google_containers/pause:3.1   "/pause"                 Less than a second ago   Up Less than a second                       k8s_POD_kube-proxy-w9jxm_kube-system_b2e2556d-2cc3-4194-8a72-61cc8c89bd00_2
[root@server3 ~]#       ##在server3上上生成容器

k8s创建一个deployment的 时序图_nginx_37

 

5、在yaml文件中增加标签选择器

apiVersion: v1              ##版本
kind: Pod                   ##类型
metadata:                   ##数据卷
  name: demo                ##标签
  labels:
    app: demo
spec:
  containers:
  - name: vm1
    image: nginx
  - name: vm2
    image: redis             ##一个pod里可以取多个容器
  - name: vm3
    image: busybox
    command:                 ##命令
    - /bin/sh                ##执行命令
    - -c
    - sleep 300              ##持续300s
  nodeSelector:              ##标签选择器
    disktype: ssd            ##磁盘的类型 通过标签来选择节点

k8s创建一个deployment的 时序图_bash_38

 

5.2、测试:

k8s创建一个deployment的 时序图_Pod_39

k8s创建一个deployment的 时序图_Pod_40

 

因为之前给server打标签为: disktype=ssd   所以创建清单时会选择在server3上进行 

k8s创建一个deployment的 时序图_nginx_41