首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在码头日志中记录码头健康检查状态?

如何在码头日志中记录码头健康检查状态?
EN

Stack Overflow用户
提问于 2021-08-25 20:29:51
回答 1查看 1.3K关注 0票数 4

目标

我想通过验证码头日志来检查我的码头集装箱是否正常。

需求

我有两个文件,loop.sh,我给码头添加了一个健康检查,如下所示:

Dockerfile

代码语言:javascript
复制
FROM alpine
ADD . /
HEALTHCHECK --interval=1s --timeout=30s --retries=3 CMD echo {'health':'healthy'}
CMD ["sh","loop.sh"]

loop.sh

代码语言:javascript
复制
#!/bin/sh

while 1>0;do echo "1"; sleep 2; done;

观测

  • 观测1

docker logs只输出loop.sh中提到的integer 1,但不输出我的对接者的健康状态。一张图片附在下面-

  • 观测2

docker ps命令显示容器是健康的,因此推断出我的健康检查是有效的。请在下面找到附图-

  • 观测3

docker inspect命令还显示了码头容器的健康状态。请找到下面的截图-

问题

如何记录此{'health':'healthy'}健康检查状态,以便在坞日志中看到它?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-08-25 20:58:45

好吧,这是超级无趣,我不以它为荣。问题是健康检查运行在与主进程不同的进程中,因此很难写入主进程‘stdout’。

但是您可以利用主进程(通常)作为进程#1运行,并将其写入/proc/1/fd/1,即进程的stdout。就像这样

代码语言:javascript
复制
FROM ubuntu
HEALTHCHECK --interval=1s --timeout=30s --retries=3 CMD echo {'health': 'healthy'} | tee /proc/1/fd/1
CMD tail -f /dev/null

tail -f /dev/null只是一个让容器运行的虚拟命令。

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68929484

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档