小知识:浅谈Docker run 容器处于created状态问题

在最近遇到的一次问题中,有这样一种现象:

系统有一个测试脚本会不断的执行docker run命令来运行容器,在测试过程中发现有一个情况是,有时候容器没有完全被运行到”Up”状态,而是处于”created”状 态,现象十分奇怪。

上环境首先查看了”created”状态的容器,以及dockerd日志:

(1) dockerd的日志中只有”post create”请求,但是居然没有收到该容器的”post start”请求;

(2) 手动执行docker start是可以将此容器拉起到”Up”状态,说明容器、镜像本身没有问题。

综合上面现象,怀疑是”docker run“流程没有执行完毕,docker run就退出了导致。立刻翻阅”docker run”在cli/command/container/run.go中对于”docker run”命令的处理函数func runRun()的实现中有如下情况:

?
1
2
3
4
5
6
7
func runRun(dockerCli *command.DockerCli, flags *pflag.FlagSet, opts *runOptions, copts *runconfigopts.ContainerOptions) error {
。。。。。。
createResponse, err := createContainer(ctx, dockerCli, config, hostConfig, networkingConfig, hostConfig.ContainerIDFile, opts.name)
。。。。。。
if err := client.ContainerStart(ctx, createResponse.ID, types.ContainerStartOptions{}); err != nil {)
。。。。。
}

如果在执行完createContainer()函数后”docker run”命令异常退出(如遇到kill信号),此时ContainerStart()函数无法继续运行。这就会导致容器虽然创建成功处于”created”状态,但是并没有真正的给dockerd”post start”,最终造成上述现象。

因而在日常生产过程中有必要对”docker run”命令进行监控,比如判断它是否执行成功,是否异常退出,退出时返回值是否为0等等。

补充:docker运行容器后处于运行状态三种方法

第一种解决方法

我们在运行docker容器的时候很多时候处于 Exited状态。

比如下面的命令 docker run -d –name nginx -P nginx /bin/bash 这种交互形式在运行完之后就会退出,重新docker start的也没有用;

如果想在运行之后容器处于运行状态只需把/bin/bash去掉即可。

第二种解决方法

?
1
docker run -it –name nginxit -P nginx

现在容器nginxit处于退出状态;

只要我们用docker启动下就可以使用

?
1
docker start nginxit

第三种和第二种类似:

?
1
docker run -it –name nginxit2 -P nginx /bin/bash

前后台交互需要退出:

?
1
root@de4dbb27f905:/# exit

然后再重启:

?
1
docker start nginxit2

以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。如有错误或未考虑完全的地方,望不吝赐教。

原文链接:https://blog.csdn.net/wennuanddianbo/article/details/103397847

声明: 猿站网有关资源均来自网络搜集与网友提供,任何涉及商业盈利目的的均不得使用,否则产生的一切后果将由您自己承担! 本平台资源仅供个人学习交流、测试使用 所有内容请在下载后24小时内删除,制止非法恶意传播,不对任何下载或转载者造成的危害负任何法律责任!也请大家支持、购置正版! 。本站一律禁止以任何方式发布或转载任何违法的相关信息访客发现请向站长举报,会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。本网站的资源部分来源于网络,如有侵权烦请发送邮件至:2697268773@qq.com进行处理。
建站知识

小知识:docker 内存监控与压测方式

2023-3-23 17:58:30

建站知识

小知识:docker logs-查看docker容器日志的实现

2023-3-23 18:09:12

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索