Kubernetes—有状态应用部署

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启动顺序和唯一性

  1. 稳定,唯一的网络标识符,持久存储
  2. 有序,优雅的部署和扩展、删除和终止
  3. 有序,滚动更新
    三个组件: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
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

来自万古的忧伤

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值