一、概念
有状态:db 如果mysql的主从,必须是远程的存储,在任意节点都可以挂载恢复之前的状态,而且还有网络ID唯一,从得知道主的地址,pod是短暂的,新的就会换IP,得保证这个IP能一直在使用
无状态:web 比如部署2个副本,跟其他没啥直接的关系,本地也没有需要持久化的数据,其中有一个副本挂了,其他节点起来仍然可以提供服务没有影响
K8S适合访问波动大、版本迭代快的、弹性伸缩的
二、特点
#1.无状态应用(Deployment)
1)认为Pod都是一样的
2)没有顺序要求
3)不用考虑在那个node运行
4)随意进行伸缩和扩展
#2.有状态应用
1)上面因素都需要考虑到
2)让每个Pod独立的,保持Pod启动顺序和唯一性
3)唯一的网络标识符,持久存储
4)有序性,比如mysql主从
三、Headless Service
kubernates中还有一种service类型:headless serivces功能,字面意思无头service其实就是该service对外无提供IP,即ClusterIP: none。一般用于对外提供域名服务的时候。
[root@kubernetes-master-001 ~]# vim headless-service.yaml
kind: Service
apiVersion: v1
metadata:
name: nginx
labels:
app: nginx
spec:
clusterIP: None
selector:
app: nginx
ports:
- port: 80
targetPort: 80
name: web
---
apiVersion: apps/v1
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
[root@kubernetes-master-001 ~]# 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 443/TCP 3d2h
service/nginx ClusterIP None 80/TCP 3m3s
service/web ClusterIP 10.100.37.233 80/TCP 47h
service/web1 NodePort 10.103.214.171 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)
官方文档:https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/
StatefulSet与Deployment区别:statefulset是有身份的(唯一标识的)
身份三要素: ? 域名 ? 主机名 ? 存储(PVC)
#1.主机名 + 按照一定规则生成域名
每个pod有唯一主机名
唯一域名:
格式: 主机名称.service.名称空间.svc.cluster.local
ClusterIP A记录格式: ..svc.cluster.local
ClusterIP=None A记录格式: .
..svc.cluster.local
举例:nginx-statefulset-0.nginx.default.svc.cluster.local