欢迎来到代码驿站!

当前位置:首页 >

浅谈Docker run 容器处于created状态问题

时间:2022-09-18 11:12:25|栏目:|点击:

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

系统有一个测试脚本会不断的执行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()的实现中有如下情况:

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去掉即可。

第二种解决方法

docker run -it --name nginxit -P nginx

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

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

docker start nginxit

第三种和第二种类似:

docker run -it --name nginxit2 -P nginx /bin/bash

前后台交互需要退出:

root@de4dbb27f905:/# exit

然后再重启:

docker start nginxit2

上一篇:Web开发人员常用速查手册 英文集合推荐

栏    目:

下一篇:关于zabbix自定义监控项和触发器问题

本文标题:浅谈Docker run 容器处于created状态问题

本文地址:http://www.codeinn.net/misctech/213965.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有