一、三大探测简单说明
Kubernetes(k8s)提供了多种容器探测机制,用于定期诊断容器的健康状况。主要的探测类型包括:
startupProbe(启动探测):这种探测用于确定容器中的应用是否已经成功启动。如果指定了启动探测,那么其他所有探测将被禁用,直到启动探测成功为止。如果启动探测失败,kubelet将根据容器的重启策略来决定是否杀死并重启该容器。
livenessProbe(存活性探测):存活性探测用于定期检查容器内的应用是否仍在运行。在某些情况下,应用程序可能因为长时间运行或其他原因过渡到无法正常运行的状态。存活性探测可以检测这种情况,并通知kubelet重新启动容器,以确保应用持续可用。
readinessProbe(就绪性探测):就绪性探测用于确定容器是否已经准备好接收流量。当一个Pod内的所有容器都通过就绪性探测时,这个Pod才被视为就绪,可以开始处理流量。这种探测常用于控制哪个Pod应该作为Service的后端。
二、实战运用
这里以nginx的部署为例子,对80进行探测
apiVersion: v1
kind: Service
metadata:
name: nginx-live
labels:
app: nginx
spec:
type: NodePort
ports:
- name: server
port: 80
targetPort: 80
nodePort: 31180
selector:
app: nginx
---
apiVersion: v1
kind: Pod
metadata:
name: nginx-live
labels:
app: nginx
spec:
containers:
- name: nginx
image: nginx
ports:
- name: server
containerPort: 80
- name: management
containerPort: 80
readinessProbe:
initialDelaySeconds: 20
periodSeconds: 5
timeoutSeconds: 10
httpGet:
scheme: HTTP
port: 80
path: /
livenessProbe:
initialDelaySeconds: 20
periodSeconds: 5
timeoutSeconds: 10
httpGet:
scheme: HTTP
port: 80
path: /
startupProbe:
initialDelaySeconds: 20
periodSeconds: 5
timeoutSeconds: 10
httpGet:
scheme: HTTP
port: 80
path: /
以下是容器的创建过程,可以看到在12S的时候runing了,但是还是0/1,直到探测通过才是1/1。