健康检查机制

Posted yangxiaoni

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了健康检查机制相关的知识,希望对你有一定的参考价值。

1.探针的种类

livenessProbe: 健康状态检查,周期性检查服务是否存活,检查结果失败,将重启容器。

readinessProbe: 可用性检查,周期性检查服务是否可以,不可用将从service的endpoints中移除。

2.探针的检测方法:

  • exec : 执行一段命令,返回值为0 或非 0
  • httpGet: 检测某个http请求返回的状态码2xx 3xx正常,4xx,5xx错误
  • tcpSocket: 测试某个端口是否能够连接

3.1 liveness探针的exec使用

vi  nginx_pod_exec.yaml 
apiVersion: v1
kind: Pod
metadata:
  name: exec
spec:
  containers:
    - name: nginx
      image: 10.0.0.11:5000/nginx:1.13
      ports:
        - containerPort: 80
      args:
        - /bin/sh
        - -c
        - touch /tmp/healthy; sleep 30; rm -rf /tmp/healthy; sleep 600
      livenessProbe:
        exec:
          command:
            - cat
            - /tmp/healthy
        initialDelaySeconds: 5       #初始化检查,第一次检查在容器起来之后的第几秒
        periodSeconds: 5            #多长时间检查一次
        timeoutSeconds: 5            #超时时间
        successThreshold: 1            #成功几次代表是健康的
        failureThreshold: 1            #失败几次

3.2 liveness探针的httpGet使用

```vi nginx_pod_httpGet.yaml
apiVersion: v1
kind: Pod
metadata:
name: httpget
spec:
containers:
- name: nginx
image: 10.0.0.11:5000/nginx:1.13
ports:
- containerPort: 80
livenessProbe:
httpGet:
path: /index.html
port: 80
initialDelaySeconds: 3
periodSeconds: 3

###    3.3 liceness探针的tcpSocket使用

vi nginx_pod_tcpSocket.yaml
apiVersion: v1
kind: Pod
metadata:
name: tcpSocket
spec:
containers:
- name: nginx
image: 10.0.0.11:5000/nginx:1.13
ports:
- containerPort: 80
args:
- /bin/sh
- -c
- tail -f /etc/hosts
livenessProbe:
tcpSocket:
port: 80
initialDelaySeconds: 10
periodSeconds: 3

###    4.1readiness 探针的httpGet使用

vi nginx-rc-httpGet.yaml
iapiVersion: v1
kind: ReplicationController
metadata:
name: readiness
spec:
replicas: 2
selector:
app: readiness
template:
metadata:
labels:
app: readiness
spec:
containers:
- name: readiness
image: 10.0.0.11:5000/nginx:1.13
ports:
- containerPort: 80
readinessProbe:
httpGet:
path: /qiangge.html
port: 80
initialDelaySeconds: 3
periodSeconds: 3
```

以上是关于健康检查机制的主要内容,如果未能解决你的问题,请参考以下文章

Knative Serving 健康检查机制分析

Nacos临时实例和永久实例的区别以及健康检查机制

k8s探测机制之pod健康检查

详解nginx的原生被动健康检查机制&灾备使用(含测试)

[转]Eureka自我保护机制健康检查的作用actuator模块监控

微服务:剖析一下源码,Nacos的健康检查竟如此简单