赞
踩
目录
pod控制器,又称为工作负载(workload),是用于实现管理pod的中间层,确保pod资源符合预期的状态,pod的资源出现故障时,会尝试进行重启,当重启策略无效,会重新创建新的pod。
在kubernetes中,按照pod的创建安方式可以将其分为两类:
pod控制器分为有状态和无状态的
有状态:
1.实例之间有差别,每个实例都有自己的独特性,元数据不同,例如etcd,zookeeper
2.实例之间不对等的关系,以及依靠外部存储的应用无状态:
1.deployment认为所有的pod都是一样的
2.不用考虑顺序的要求
3.不用考虑在哪个node节点上运行
4.可以随意扩容和缩容
常规service和无头服务的区别:
service:一组pod访问策略,提供cluster-ip集群之间通讯,还提供负载均衡和服务发现
Headless service:无头服务,不需要cluster-ip,直接绑定具体的pod的IP
1、ReplicaSet: 代用户创建指定数量的pod副本数量,确保pod副本数量符合预期状态,并且支持滚动式自动扩容和缩容功能。
ReplicaSet主要三个组件组成:
(1)用户期望的pod副本数量
(2)标签选择器,判断哪个pod归自己管理
(3)当现存的pod数量不足,会根据pod资源模板进行新建
帮助用户管理无状态的pod资源,精确反应用户定义的目标数量,但是RelicaSet不是直接使用的控制器,而是使用Deployment
2、Deployment:工作在ReplicaSet之上,用于管理无状态应用,目前来说最好的控制器。支持滚动更新和回滚功能,还提供声明式配置。
ReplicaSet 与Deployment 这两个资源对象逐步替换之前RC的作用。
3、DaemonSet:用于确保集群中的每一个节点只运行特定的pod副本,通常用于实现系统级后台任务。比如ELK服务
4、StatefulSet:管理有状态应用
5、Job:只要完成就立即退出,不需要重启或重建
6、Cronjob:周期性任务控制,不需要持续后台运行
为了更好的解决服务编排的问题,kubernetes在v1.2版本开始,引入了Deployment控制。值得一提的是,这种控制器并不直接管理pod,而是通过管理 ReplicaSet 来间接管理Pod,即:Deployment管理ReplicaSet,ReplicaSet管理Pod。所以Deployment比ReplicaSet功能更加强大。
Deployment主要功能有下面几个:
特点:
应用场景:应用场景: Nginx, 微服务,jar
- apiVersion: apps/v1 # 版本号
- kind: Deployment # 类型
- metadata: # 元数据
- name: # rs名称
- namespace: # 所属命名空间
- labels: #标签
- controller: deploy
- spec: # 详情描述
- replicas: 3 # 副本数量
- revisionHistoryLimit: 3 # 保留历史版本,默认是10,用于版本回退时使用
- paused: false # 暂停部署,默认是false,即deployment创建好后是否立即开始部署和创建pod
- progressDeadlineSeconds: 600 # 部署超时时间(s),默认是600
- strategy: # 策略
- type: RollingUpdate # 滚动更新策略
- rollingUpdate: # 滚动更新
- maxSurge: 30% # 最大额外可以存在的副本数,可以为百分比,也可以为整数
- maxUnavailable: 30% # 最大不可用状态的 Pod 的最大值,可以为百分比,也可以为整数
- selector: # 选择器,通过它指定该控制器管理哪些pod
- matchLabels: # Labels匹配规则
- app: nginx-pod
- matchExpressions: # Expressions匹配规则
- - {key: app, operator: In, values: [nginx-pod]}
- template: # 模板,当副本数量不足时,会根据下面的模板创建pod副本
- metadata:
- labels:
- app: nginx-pod
- spec:
- containers:
- - name: nginx
- image: nginx:1.17.1
- ports:
- - containerPort: 80
上述资源清单可以分为三部分,spec以上是deployment信息;spec的replicas到selector是副本数量、镜像更新策略、标签选择器(会和下面的Pod做关联)等;template及以下是Pod配置信息。
创建pc-deployment.yaml,内容如下:
- # vim nginx-deployment.yaml
- apiVersion: apps/v1
- kind: Deployment
- metadata:
- name: nginx-deployment
- labels:
- app: nginx
- spec:
- replicas: 3
- selector:
- matchLabels:
- app: nginx
- template:
- metadata:
- labels:
- app: nginx
- spec:
- containers:
- - name: nginx
- image: nginx:1.15.4
- ports:
- - containerPort: 80
- Replicaset是副本数,回滚就是通过此来实现
-
- 创建资源
- # kubectl create -f nginx-deployment.yaml
- 查看创建的pod资源、控制器和副本
- # kubectl get pods,deploy,rs
- 查看历史版本
- # kubectl rollout history deployment/nginx-deployment
ReplicaSet的主要作用是保证一定数量的pod正常运行,它会持续监听这些Pod的运行状态,一旦Pod发生故障,就会重启或重建。同时它还支持对pod数量的扩缩容和镜像版本的升降级。
- apiVersion: apps/v1 # 版本号
- kind: ReplicaSet # 类型
- metadata: # 元数据
- name: # rs名称
- namespace: # 所属命名空间
- labels: #标签
- controller: rs
- spec: # 详情描述
- replicas: 3 # 副本数量
- selector: # 选择器,通过它指定该控制器管理哪些pod
- matchLabels: # Labels匹配规则
- app: nginx-pod
- matchExpressions: # Expressions匹配规则
- - {key: app, operator: In, values: [nginx-pod]}
- template: # 模板,当副本数量不足时,会根据下面的模板创建pod副本
- metadata:
- labels:
- app: nginx-pod
- spec:
- containers:
- - name: nginx
- image: nginx:1.17.1
- ports:
- - containerPort: 80
在这里面,需要新了解的配置项就是spec下面几个选项:
创建pc-replicaset.yaml文件,内容如下:
- apiVersion: apps/v1
- kind: ReplicaSet
- metadata:
- name: pc-replicaset
- namespace: dev
- spec:
- replicas: 3
- selector:
- matchLabels:
- app: nginx-pod
- template:
- metadata:
- labels:
- app: nginx-pod
- spec:
- containers:
- - name: nginx
- image: nginx:1.17.1
- # 创建rs
- [root@master ~]# kubectl create -f pc-replicaset.yaml
- replicaset.apps/pc-replicaset created
- # 查看rs
- # DESIRED:期望副本数量
- # CURRENT:当前副本数量
- # READY:已经准备好提供服务的副本数量
- [root@master ~]# kubectl get rs pc-replicaset -n dev -o wide
- NAME DESIRED CORRENT READY AGE CONTAINERS IMAGES SELECTOR
- pc-replicaset 3 3 3 22s nginx nginx:1.17.1 app=nginx-pod
-
- # 查看当前控制器创建出来的pod
- # 这里发现控制器创建出来的pod的名称是在控制器名称后面拼接了-xxxx随机码
- [root@master ~]# kubectl get pod -n dev
- NAME READY STATUS RESTARTS AGE
- pc-replicaset-6vmvt 1/1 Running 0 54s
- pc-replicaset-fm8f 1/1 Running 0 54s
- pc-replicaset-snrk 1/1 Running 0 54s
应用场景:数据库,Mysql主从,zookeeper集群,etcd集群
无论是Kube-dns还是CoreDNS,基本原理都是利用监听Kubernetes的Service和Pod,生成DNS记录,然后通过重新配置Kubelet的DNS选项让新启动的Pod使用Kube-dns或CoreDNS提供的
无状态
有状态
PS:k8s暴露方式主要就3种:ingress loadbalance(SLB/ALB K8S集群外的负载均衡器、Ng、harproxy、KONG、traefik等等) service
- vim nginx-service.yaml
-
- apiVersion: v1
- kind: Service
- metadata:
- name: nginx-svc
- labels:
- app: nginx
- spec:
- type: NodePort
- ports:
- - port: 80
- targetPort: 80
- selector:
- app: nginx
在node节点操作,查看集群间通讯
因为Pod动态IP地址,所以常用于绑定DNS访问—来尽可能固定Pod的位置
- [root@master demo]# vim headless.yaml
-
- apiVersion: v1
- kind: Service
- metadata:
- name: nginx
- labels:
- app: nginx
- spec:
- ports:
- - port: 80
- name: web
- clusterIP: None
- selector:
- app: nginx
-
- kubectl apply -f headless.yaml
- kubectl get svc
再定义一个pod
- [root@master demo]# vim dns-test.yaml
-
- apiVersion: v1
- kind: Pod
- metadata:
- name: dns-test
- spec:
- containers:
- - name: busybox
- image: busybox:1.28.4
- args:
- - /bin/sh
- - -c
- - sleep 36000
- restartPolicy: Never
验证dns解析
- kubectl create -f dns-test.yaml
- kubectl get svc
解析kubernetes和nginx-svc名称
kubectl exec -it dns-test sh
创建StatefulSet.yaml文件
- vim statefulSet.yaml
-
- apiVersion: v1
- kind: Service
- metadata:
- name: nginx
- labels:
- app: nginx
- spec:
- ports:
- - port: 80
- name: web
- clusterIP: None
- selector:
- app: nginx
- ---
- apiVersion: apps/v1beta1
- kind: StatefulSet
- metadata:
- name: nginx-statefulset
- namespace: default
- spec:
- serviceName: nginx
- replicas: 3
- selector:
- matchLabels:
- app: nginx
- template:
- metadata:
- labels:
- app: nginx
- spec:
- containers:
- - name: nginx
- image: nginx:latest
- ports:
- - containerPort: 80
-
清理所有pod
kubectl delete -f .
- kubectl create -f statefulSet.yaml
- kubectl get pods,svc
解析pod的唯一域名和自身的ip
- kubectl apply -f dns-test.yaml
-
- kubectl exec -it dns-test sh
-
- nslookup nginx-statefulset-0.nginx
- nslookup nginx-statefulset-1.nginx
- nslookup nginx-statefulset-2.nginx
总结
StatefulSet与Deployment区别:有身份的!
身份三要素:
无状态服务对象-Deployment:用于部署无状态的服务,一般用于管理维护企业内部无状态的微服务,比如configserver、zuul、springboot。其可以管理多个副本的Pod实现无缝迁移、自动扩容缩容、自动灾难恢复、一键回滚等功能。其服务部署结构模型是Deployment->ReplicaSet->Pod;Deployment工作在ReplicaSet之上,用于管理无状态应用,通过“控制器模式”,来操作 ReplicaSet 的个数和属性,进而实现“水平扩展 / 收缩”和“滚动更新”这两个编排动作,也就是说,Deployment 控制器实际操纵的是ReplicaSet 对象,而不是 Pod 对象
有状态服务-statefuleset:用于管理有状态应用程序的工作负载API对象。比如在生产环境中,可以部署ElasticSearch集群、MongoDB集群或者需要持久化的RabbitMQ集群、Redis集群、Kafka集群和ZooKeeper集群等,其解决了有状态服务使用容器化部署的一个问题,保证pod的hostname重启/重建后不变,通过hostname维护关联数据。其服务部署结构模型是Statefulset->ReplicaSet->Pod;Statefulset也是工作在Replicaset之上,用于管理有状态服务。有状态部署的产品设置通无状态部署
daemonset确保全部(或者一些)node上运行一个pod副本,当有node加入集群时,也会为他们新增一个pod。当有node从集群移除时,这些pod也会被回收。删除daemonset将会删除它创建的所有的pod
应用场景:运行日志收集,监控,集群存储daemon
- [root@master demo]# vim daemonSet.yaml
-
- apiVersion: apps/v1
- kind: DaemonSet
- metadata:
- name: nginx-deployment
- labels:
- app: nginx
- spec:
- selector:
- matchLabels:
- app: nginx
- template:
- metadata:
- labels:
- app: nginx
- spec:
- containers:
- - name: nginx
- image: nginx:1.15.4
- ports:
- - containerPort: 80
DaemonSet会在每个node节点都创建一个Pod
- kubectl apply -f daemonSet.yaml
- kubectl get pods
Job分为普通任务(Job)和定时任务(CronJob)
一次性执行
应用场景:离线数据处理,视频解码等业务
官方案例
应用大数据场景
示例:
用job控制器类型创建资源,执行算圆周率的命令,保持后2000位,创建过程等同于在计算
,重试次数默认是6次,修改为4次,当遇到异常时Never状态会重启,所以要设定次数。
- [root@master demo]# vim job.yaml
-
- apiVersion: batch/v1
- kind: Job
- metadata:
- name: pi
- spec:
- template:
- spec:
- containers:
- - name: pi
- image: perl:5.34.0
- command: ["perl", "-Mbignum=bpi", "-wle", "print bpi(2000)"]
- restartPolicy: Never
- backoffLimit: 4
-
在node1节点下载perl镜像,因为镜像比较大所以提前下载好
docker pull perl
创建
查看到完成状态
结果输出到控制台
清除job资源
- kubectl get job
- kubectl delete -f job.yaml
官方示例:Running Automated Tasks with a CronJob | Kubernetes
示例:
每隔一分钟输出一条信息,打印hello
- [root@master demo]# vim cronjob.yaml
-
- apiVersion: batch/v1beta1
- kind: CronJob
- metadata:
- name: lcdb
- spec:
- schedule: "*/1 * * * *"
- jobTemplate:
- spec:
- template:
- spec:
- containers:
- - name: lcdb
- image: busybox
- args:
- - /bin/sh
- - -c
- - date; echo lcdb from the Kubernetes cluster
- restartPolicy: OnFailure
- kubectl apply -f cronjob.yaml
-
- kubectl get pod
- kubectl get cronjob
清除cronjob资源
kubectl delete -f cronjob.yaml
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。