kubernetes 部署有状态应用

kubernetes 部署有状态应用

一、概念

有状态:db 如果 mysql 的主从,必须是远程的存储,在任意节点都可以挂载恢复之前的状态,而且还有网络 ID 唯一,从得知道主的地址,pod 是短暂的,新的就会换IP,得保证这个 IP 能一直在使用。
无状态:web 比如部署 2 个副本,跟其他没啥直接的关系,本地也没有需要持久化的数据,其中有一个副本挂了,其他节点起来仍然可以提供服务没有影响。
K8S 适合访问波动大、版本迭代快的、弹性伸缩的。

二、特点

1、无状态应用(Deployment)

  • 认为 Pod 都是一样的
  • 没有顺序要求
  • 不用考虑在那个 node 运行
  • 随意进行伸缩和扩展

2、有状态应用

  • 上面因素都需要考虑到
  • 让每个 Pod 独立的,保持 Pod 启动顺序和唯一性
  • 唯一的网络标识符,持久存储
  • 有序性,比如 mysql 主从

三、Headless Service

kubernates 中还有一种 service 类型:headless serivces功能,字面意思无头 service 其实就是该 service 对外无提供 IP,即 ClusterIP: none。一般用于对外提供域名服务的时候。
headless-service.yaml

kind: Service
apiVersion: v1
metadata:
  name: nginx
  labels:
    app: nginx
spec:
  clusterIP: None  # 设置为 None 表示这是一个 Headless Service
  selector:
    app: nginx
  ports:
    - port: 80
      targetPort: 80
      name: web
---

apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: nginx-statefulset
  namespace: default
spec:
  serviceName: nginx  # 关联的 Service 名称
  replicas: 3  # 副本数
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
        - name: nginx
          image: nginx:latest
          ports:
            - containerPort: 80

操作

kubectl apply -f headless-service.yaml
service/nginx created
statefulset.apps/nginx-statefulset created

查看

[root@kubernetes-master-001 ~]# kubectl  get  svc,pods
NAME                 TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)        AGE
service/kubernetes   ClusterIP   10.96.0.1        <none>        443/TCP        3d2h
service/nginx        ClusterIP   None             <none>        80/TCP         3m3s
service/web          ClusterIP   10.100.37.233    <none>        80/TCP         47h
service/web1         NodePort    10.103.214.171   <none>        80:32023/TCP   47h

NAME                       READY   STATUS    RESTARTS   AGE
pod/nginx-statefulset-0    1/1     Running   0          2m36s
pod/nginx-statefulset-1    1/1     Running   0          119s
pod/nginx-statefulset-2    1/1     Running   0          97s
pod/web-5bb6fd4c98-54ll2   1/1     Running   0          47h
pod/web-5bb6fd4c98-585rn   1/1     Running   0          47h

四、statefulset(简称sts)

官方文档:statefulset
StatefulSet 与 Deployment 区别:statefulset 是有身份的(唯一标识的)。
身份三要素:域名主机名存储(PVC)

这里有状态的约定,肯定不是简简单单通过名称来进行约定,而是更加复杂的操作。

  • deployment:是有身份的,有唯一标识
  • statefulset:根据主机名 + 按照一定规则生成域名

每个pod有唯一的主机名,并且有唯一的域名

  • 格式:主机名称.service名称.名称空间.svc.cluster.local
  • 举例:nginx-statefulset-0.default.svc.cluster.local

评论

暂无

添加新评论