Linux:kubernetes(k8s)探针的简介(7)

相当于我们用于监控容器的一个东西,通过给我们的不同探针来判断容器内的状态情况,实现故障的一个自动恢复。

我们在上一章的yaml文件中写入了一个这个东西

那么他什么情况下重启,就是通过探针进行一个监控,加入监控某一个端口,发现停止工作了,那么就立即根据事先定义的重启策略进行一个重启,但是另外一个端口没有监控,即使他停止工作了,探针也不会去做任何事情,这就是LivenessProbe探针
还有一种情况就是,假如我们的一个服务在启动后需要有一系列的初始化操作非常耗时,在初始化期间我禁止别的用户来对我进行一个访问,就是让pod是一个没有完成启动的一个状态,当我的一系列初始完成后,再进行一个对外服务,也就是通过探针对服务的一个健康值进行一个检查,判断是否可以接收外部流量,这就是ReadinessProbe探针
前两个探针通过算秒的方式来确定是否应该执行操作,比如我等你10秒你启动http,如果没启动那我就把你重启,可是http要是就是第11秒启动,这样就造成了一个死循环,根据这个缺点kubenetes就在1.16版本后又新加了一个新探针名为:StartupProbe这个探针执行的时候其他探针都不能执行,也就是这个的权限是最高的,他用于对某个服务进行监控,假如你要监控这个服务就是初始化的最后一个,监控到他的时候就结束这个探针,让后其他的探针就开始操作


三种工作模式

  • ExecAction

    使用命令进行一个检查,比如对某个文件进行检查,如果他存在就是成功了,没存在就是失败了

  • TCPSocketAction

    通过 tcp 连接监测容器内端口是否开放,如果开放则证明该容器健康

  • HTTPGetAction

    对某个端口进行请求,进行一个判断

此外还有一些比较经典的配置参数

initialDelaySeconds: 60 # 初始化时间

timeoutSeconds: 2 # 超时时间

periodSeconds: 5 # 监测间隔时间

successThreshold: 1 # 检查 1 次成功就表示成功

failureThreshold: 2 # 监测失败 2 次就表示失败

相关推荐
正经教主34 分钟前
【docker基础】 第七课:Docker Compose 多容器实战
运维·docker·容器
正经教主43 分钟前
【docker基础】Redis的docker部署
redis·docker·容器
DolphinScheduler社区1 小时前
Apache DolphinScheduler 3.4.2 正式发布!新增 Amazon EMR Serverless 插件,增强监控与补数据能力
大数据·云原生·serverless·apache·海豚调度·版本发版
成为你的宁宁1 小时前
【基于 Prometheus Operator 实现 K8s 环境下 Redis Cluster 集群监控部署】
redis·kubernetes·prometheus
是一个Bug1 小时前
Docker 与 Kubernetes:从“集装箱”到“远洋舰队”
docker·容器·kubernetes
heimeiyingwang1 小时前
【架构实战】注册中心选型:Nacos vs Eureka vs Consul
微服务·云原生·架构
java_cj1 小时前
阅读 k8s 源码的准备工作
云原生·容器·kubernetes
开发者联盟league2 小时前
使用Jenkins整合Sonarqube/Gitlab/Harbor/Kubernetes实现CICD
kubernetes·gitlab·jenkins
蜀道山老天师2 小时前
OpenClaw 从零部署 + 飞书机器人完整接入(实操篇)
运维·docker·容器·飞书
robinLi09132 小时前
docker mac 下载不同系统架构镜像
macos·docker·容器