Kubernetes—有状态应用部署
1.概念有状态:db如果mysql的主从,必须是远程的存储,在任意节点都可以挂载恢复之前的状态,而且还有网络ID唯一,从得知道主的地址,pod是短暂的,新的就会换IP,得保证这个IP能一直在使用无状态:web 比如部署2个副本,跟其他没啥直接的关系,本地也没有需要持久化的数据,其中有一个副本挂了,其他节点起来仍然可以提供服务没有影响K8S适合访问波动大、版本迭代快的、弹性伸缩的2.He...
1.概念
有状态:db 如果mysql的主从,必须是远程的存储,在任意节点都可以挂载恢复之前的状态,而且还有网络ID唯一,从得知道主的地址,pod是短暂的,新的就会换IP,得保证这个IP能一直在使用
无状态:web 比如部署2个副本,跟其他没啥直接的关系,本地也没有需要持久化的数据,其中有一个副本挂了,其他节点起来仍然可以提供服务没有影响
K8S适合访问波动大、版本迭代快的、弹性伸缩的
2.Headless Service
确保解析的名称直达pod,给pod配置唯一名称
3.StatefulSet(简称sts)
官方文档:https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/
StatefulSet与Deployment区别:有身份的!身份三要素: • 域名 • 主机名 • 存储(PVC)
ClusterIP A记录格式: ..svc.cluster.local
ClusterIP=None A记录格式: .
..svc.cluster.local
示例:web-0.nginx.default.svc.cluster.local
• 部署有状态应用
• 解决Pod独立生命周期,保持Pod启动顺序和唯一性
- 稳定,唯一的网络标识符,持久存储
- 有序,优雅的部署和扩展、删除和终止
- 有序,滚动更新
三个组件:headless service、StatefulSet、volumeClaimTemplate(卷申请模板)
应用场景:数据库
一个pod一个存储卷,数据名字相同,但是数据不一样
apiVersion: v1 kind: Service metadata: name: nginx labels:
app: nginx spec: ports:
- port: 80
name: web clusterIP: None selector:
app: nginx
--- apiVersion: apps/v1 kind: StatefulSet metadata: name: web spec: selector:
matchLabels:
app: nginx #通过标签选择器关联无头service和pod serviceName: "nginx" #选择无头service的名字 replicas: 3 template:
metadata:
labels:
app: nginx # 跟标签选择器中的相同
spec:
terminationGracePeriodSeconds: 10
containers:
- name: nginx
image: nginx
ports:
- containerPort: 80
name: web
volumeMounts:
- name: www
mountPath: /usr/share/nginx/html volumeClaimTemplates:
- metadata:
name: www
spec:
accessModes: [ "ReadWriteOnce" ]
storageClassName: "managed-nfs-storage" #指定存储类自动pv供给
resources:
requests:
storage: 1Gi
4.注意:
(1)如果没有自动供给,那么需要定义存储类来相关联pv,因为自动创建pvc,需要关联
需要解析的话 pod名字.无头service名字.命名空间
(2)可以直接进去其他pod nslookuo 无头service会给出不同pod的名称,可以通过名称直接通信
(3)因为是有序的,所以扩就是0-1-2-3,缩就是3-2-1-0
5更新策略
1.使用kubectl set 直接更新
2.定义更新策略
金丝雀发布
kubectl edit statefulsets.apps web
updateStrategy:
rollingUpdate:
partition: 4 #这里的数字表示你pod的最后的后缀,如果>=的就更新
type: RollingUpdate
这里更换镜像以后表示只有4更新0 1 2 3 保持不变
也可以用打补丁的方式修改,不过我这里不太会只会edit
Kubectl patch打补丁
回滚同理
kubectl rollout undo statefulset web 也是数字控制
更多推荐
所有评论(0)