作者:路多辛 2023-05-09 07:34:25
云计算
云原生 本文介绍Docker中两种原生的健康检查方式,使用起来非常方便。目前主流的容器编排框架也都自带了健康健康检查功能,这种情况下不需要使用Docker原生的健康检查方式。
成都创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:网站制作、网站设计、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的张家口网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!
健康检查机制是用来检查服务的可用性,当服务不可用时及时重启以恢复可用性。之前的文章《Kubernetes中配置livenessProbe、readinessProbe和startupProbe》讲解了Kubernetes中的各种健康检查类型和配置方法,本篇文章讲解一下docker容器的健康检查机制。
看过上文提到的那篇文章的同学型相信肯定能理解为什么需要对服务本身做健康检查。就以docker为例再解释一下,Docker Daemon用来运行和管理容器,本身会监控容器中PID为1的进程,其实在实际场景中仅监控PID为1的进程是不够的。例如当容器中的服产生死锁的情况,这时候服务虽然不能处理用户请求,但是PID为1的进程依然是运行状态。
Docker健康检查有两种方式:
在Dockerfile中使用HEALTHCHECK声明健康检查策略,容器启动后就会自动进行健康检查。HEALTHCHECK支持下列选项:
使用示例如下:
from elasticsearch:latest
HEALTHCHECK --interval=5s --timeout=2s --retries=3 \
CMD curl --silent --fail localhost:9200/_cluster/health || exit 1
在Dockerfile中HEALTHCHECK最好只写一个,如果写了多个,只有最后一个会有效。
CMD命令返回值有三种,如下
执行docker run后容器初始状态为starting,等待配置的interval时间后,开始执行健康检查。如果单次检查返回值不是0或者检查时间超过了timeout,本次检查被认为失败。如果健康检查连续失败次数超过了retries,状态就会变为unhealthy,健康检查结果一旦成功,容器就会被置为healthy状态。
示例如下:
$ docker run --rm -d \
--name=es \
--health-cmd="curl --silent --fail localhost:9200/_cluster/health || exit 1" \
--health-interval=5s \
--health-timeout=2s \
--health-retries=3 \
elasticsearch:latest
参数代表的意思和第一种方式中的相同,健康检查命令的输出存储在健康状态里,可以用docker inspect命令查看。
本文介绍了Docker中两种原生的健康检查方式,使用起来非常方便。目前主流的容器编排框架也都自带了健康健康检查功能,这种情况下不需要使用Docker原生的健康检查方式。
分享文章:Docker容器原生健康检查机制详解
网页地址:http://www.csdahua.cn/qtweb/news10/18560.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网