Dockerfile HEALTHCHECK 健康检查
一则或许对你有用的小广告
欢迎加入小哈的星球,你将获得:专属的实战项目(4个项目都能学) / 1v1 提问 / 简历修改 / Java 学习路线 / 社群讨论 / 学习打卡 / 每月赠书
《Spring AI 项目实战(问答机器人、RAG 智能客服、联网搜索)》已完结,基于
Spring AI + Spring Boot 3.x + JDK 21...,查看介绍《从零手撸:仿小红书(微服务架构)》 已完结,基于
Spring Cloud Alibaba + Spring Boot 3.x + JDK 17...,查看介绍;演示链接:http://116.62.199.48:7070/《从零手撸:前后端分离博客项目(全栈开发)》 2 期已完结,演示链接:http://116.62.199.48/
新开坑项目:《从零手撸:秒杀系统高并发优化实战》 正在更新中...,查看介绍
截止目前,星球内专栏累计输出 150w+ 字,讲解图 5110+ 张,还在持续爆肝中.. 后续还会上新更多项目,已有 4700+ 小伙伴加入学习,欢迎点击围观
HEALTHCHECK 指令用于设置 Docker 要如何判断容器状态是否正常。Docker 1.12 版本后引入了该指令。
使用格式如下:
HEALTHCHECK [选项] CMD <命令> #设置检查容器健康状况的命令
HEALTHCHECK NONE #如果基础镜像有健康检查指令,使用这行可以屏蔽掉其健康检查指令
HEALTHCHECK 支持下列选项:
--interval=<间隔>:两次健康检查的间隔,默认为 30 秒;--timeout=<时长>:健康检查命令运行超时时间,如果超过这个时间,本次健康检查就被视为失败,默认 30 秒;--retries=<次数>:健康检查重试次数,若指定次数依然失败,则将容器状态视为unhealthy,默认 3 次。
当一个镜像指定了 HEALTHCHECK 后,初启动容器时,初始状态为 starting, 当 HEALTHCHECK 指令检查成功后,容器状态会变为 healthy,如果重试多次失败,则会变为 unhealthy。
注意: 当 Dockerfile 中出现多个
HEALTHCHECK时,只有最后一个生效。
使用示例
FROM nginx
RUN apt-get update && apt-get install -y curl && rm -rf /var/lib/apt/lists/*
HEALTHCHECK \
CMD curl -fs http://localhost/ || exit 1
上面的 Dockerfile 中,通过 HEALTHCHECK 指令设置了每 5 秒检查一次,超时时间为 3 秒,若 3 秒没有响应则视为失败,并且使用 curl -fs http://localhost/ || exit 1 作为健康检查命令。
