Docker容器原生健康检查机制详解

这篇具有很好参考价值的文章主要介绍了Docker容器原生健康检查机制详解。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

为什么需要健康检查机制?

健康检查机制是用来检查服务的可用性,当服务不可用时及时重启以恢复可用性。之前的文章《Kubernetes中配置livenessProbe、readinessProbe和startupProbe》讲解了Kubernetes中的各种健康检查类型和配置方法,本篇文章讲解一下docker容器的健康检查机制。

看过上文提到的那篇文章的同学型相信肯定能理解为什么需要对服务本身做健康检查。就以docker为例再解释一下,Docker Daemon用来运行和管理容器,本身会监控容器中PID为1的进程,其实在实际场景中仅监控PID为1的进程是不够的。例如当容器中的服产生死锁的情况,这时候服务虽然不能处理用户请求,但是PID为1的进程依然是运行状态。

Docker健康检查机制

Docker健康检查有两种方式:

  • 在Dockerfile中使用HEALTHCHECK命令配置健康检查策略;
  • 在启动容器时(docker run 命令)配置健康检查策略。

在Dockerfile中使用HEALTHCHECK命令配置健康检查策略

在Dockerfile中使用HEALTHCHECK声明健康检查策略,容器启动后就会自动进行健康检查。HEALTHCHECK支持下列选项:

  • --interval=<间隔时间>:两次健康检查的间隔时间,默认30 秒;
  • --timeout=<超时时间>:健康检查命令运行超时时间,如果超过这个时间,本次健康检查被视为失败,默认 30 秒;
  • --retries=<重试次数>:当连续重试指定次数后,则将容器状态置为 unhealthy,默认 3 次。
  • --start-period=<间隔>: 应用启动时间,不计启动过程中的健康检查失效情况,默认 0 秒。

使用示例如下:

from elasticsearch:latest
HEALTHCHECK --interval=5s --timeout=2s --retries=3 \
CMD curl --silent --fail localhost:9200/_cluster/health || exit 1

在Dockerfile中HEALTHCHECK最好只写一个,如果写了多个,只有最后一个会有效。

CMD命令返回值有三种,如下

  • 0,成功;
  • 1,失败;
  • 2,保留值,不要使用。

执行docker run后容器初始状态为starting,等待配置的interval时间后,开始执行健康检查。如果单次检查返回值不是0或者检查时间超过了timeout,本次检查被认为失败。如果健康检查连续失败次数超过了retries,状态就会变为unhealthy,健康检查结果一旦成功,容器就会被置为healthy状态。

在启动容器时(docker run 命令)配置健康检查策略

示例如下,

$ 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原生的健康检查方式。文章来源地址https://www.toymoban.com/news/detail-431348.html

到了这里,关于Docker容器原生健康检查机制详解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【容器架构】你知道有 Docker 为什么还要 K8s 吗?

    👉 博主介绍 : 博主从事应用安全和大数据领域,有8年研发经验,5年面试官经验,Java技术专家,WEB架构师,阿里云专家博主,华为云云享专家,51CTO TOP红人 Java知识图谱点击链接: 体系化学习Java(Java面试专题) 💕💕 感兴趣的同学可以收藏关注下 , 不然下次找不到哟

    2024年02月16日
    浏览(55)
  • Nacos架构与原理 - 健康检查机制

    想象发生地质灾害,被掩埋在废墟下,搜救队需定位才能施救。两种方法: 大喊求救,告知位置与健康状况,让搜救队知晓 搜救队使用专业设备探测到被埋者位置 这两种方法可类比为服务探测方式: 客户端主动上报,告知服务端自己健康状态。若一段时间无上报,判定服务不健康。

    2024年02月08日
    浏览(39)
  • 【云原生】第八篇--Docker容器数据持久化存储机制

    物理机或虚拟机数据持久化存储 由于物理机或虚拟机本身就拥有大容量的磁盘,所以可以直接

    2023年04月09日
    浏览(29)
  • k8s之Pod及Probe 探针机制(健康检查机制)

    1.1、定义 Pod 是一组(一个或多个) 容器(docker容器)的集合 (就像在豌豆荚中);这些容器共享存储、网络、以及怎样运行这些容器的声明 - 我们一般不直接创建Pod,而是创建一些工作负载由他们来创建Pod 1.2、Pod的形式 Pod对容器有自恢复能力(Pod自动重启失败的容器)

    2024年02月12日
    浏览(33)
  • 为什么不要相信AI机器人提供的健康信息?

    自从OpenAI、微软和谷歌推出了AI聊天机器人,许多人开始尝试一种新的互联网搜索方式:与一个模型进行对话,而它从整个网络上学到的知识。 专家表示,鉴于之前我们倾向于通过搜索引擎查询健康问题,我们也不可避免地会向ChatGPT、Bing和Bard等工具提问。然而,这些工具会

    2024年02月08日
    浏览(38)
  • Nacos实战(19)-Nacos健康检查机制:保障你的服务稳定运行!

    注册中心不应仅提供服务注册和发现功能,还应保证对服务可用性监测,对不健康的服务和过期的进行标识或剔除,维护实例的生命周期,以保证客户端尽可能的查询到可用的服务列表。 因此本文介绍Nacos注册中心的健康检查机制。 知道⼀个服务是否还健康的方式: 客户端

    2024年02月09日
    浏览(35)
  • 【探索 Kubernetes|作业管理篇 系列 10】Pod 健康检查和恢复机制

    大家好,我是秋意零。 上一篇中介绍了,Pod 的服务对象,从而对 Pod 有了更深的理解; 今天的主题是 Pod 健康检查和恢复机制,我们将结束 Pod 的内容。 最近搞了一个扣扣群,旨在技术交流、博客互助,希望各位大佬多多支持!在我主页推广区域,如图: 文章底部推广区域

    2024年02月09日
    浏览(26)
  • TypeScript:为什么JavaScript需要类型检查?

    JavaScript是当今最为流行的编程语言之一。它是一种高级的、解释性的编程语言,用于Web应用程序的开发。然而,JavaScript的灵活性也是它的弱点之一。JavaScript中的变量、函数、类等都是动态类型,这意味着它们的类型可以在运行时发生变化。虽然这种灵活性为JavaScript开发人员

    2024年02月04日
    浏览(44)
  • 网络审计:为什么定期检查您的网络很重要

    本文分享自天翼云开发者社区《网络审计:为什么定期检查您的网络很重要》,作者:易乾 在数字化时代,网络安全成为组织和个人必须面对的重要挑战。网络审计是一种关键的安全措施,通过定期检查和评估网络系统的安全性,帮助发现潜在的安全漏洞和弱点,从而防止数

    2024年04月17日
    浏览(30)
  • 【云原生】Docker 详解(一):从虚拟机到容器

    要解释清楚 Docker ,首先要解释清楚 容器 (Container)的概念。要解释容器的话,就需要从操作系统说起。操作系统太底层,细说的话一两本书都说不清楚。这里就一句话来总结一下:操作系统(Operating System,简称 OS)是管理计算机硬件与软件资源的计算机程序,并且为软件

    2024年02月13日
    浏览(25)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包