根据我到目前为止阅读的教程,使用“Docker run-d
”将从图像启动一个容器,并且容器将在后台运行。这是看起来的样子,我们可以看到我们已经有了容器ID。
root@docker:/home/root# docker run -d centos
605e3928cdddb844526bab691af51d0c9262e0a1fc3d41de3f59be1a58e1bd1d
root@docker:/home/root# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
605e3928cddd centos:latest "/bin/bash" 31 minutes ago Exited (0) 31 minutes ago kickass_swartz
我做错什么了吗?如何解决此问题?
centos dockerfile有一个默认命令bash
。
这意味着,在后台(-d
)运行时,shell会立即退出。
更新2017
docker run -t -d centos
vonc@voncvb:~$ d ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
4a50fd9e9189 centos "/bin/bash" 8 seconds ago Up 2 seconds wonderful_wright
请注意,对于alpine,Marinos A在注释中报告:
Docker run-t-d alpine/git
无法保持进程。
必须执行以下操作:Docker run--entrypoint“/bin/sh”-it alpine/git
原答案(2015年)
但是,-d
选项存在问题。除非命令继续在前台运行,否则容器将立即停止。
Docker要求您的命令继续在前台运行。否则,它认为应用程序会停止并关闭容器。
问题是某些应用程序没有在前台运行。我们怎样才能让它变得更容易?
在这种情况下,您可以将tail-f/dev/null
添加到您的命令中。
通过这样做,即使您的主命令在后台运行,您的容器也不会停止,因为tail一直在前台运行。
docker run -d centos tail -f /dev/null
ENTRYPOINT ["tail"]
CMD ["-f","/dev/null"]
Docker PS
将显示centos容器仍在运行。
从那里,您可以附加到它或从它分离(或docker exec
一些命令)。
问题内容: 根据我到目前为止阅读的教程,使用“ ”将从图像启动容器,并且该容器将在后台运行。看起来是这样,我们可以看到我们已经有了容器ID。 但是如果我运行“ ”,则什么也没有返回。 所以我尝试了“ ”,可以看到容器已经退出: 我做错了什么?如何解决此问题? 问题答案: 在CentOS的dockerfile有一个默认的命令。 这意味着,在后台()中运行时,外壳程序会立即退出。 更新2017 最近泊
根据我目前阅读的教程,使用“”将从图像启动一个容器,容器将在后台运行。这就是它的样子,我们可以看到我们已经有了容器id。 但如果我运行“”,则不会返回任何内容。 所以我尝试了“”,我可以看到容器已经退出: 我做错了什么吗?如何解决此问题?
我在官方docker网站上遵循了“开始”教程,一切都很顺利,直到我尝试删除容器。每次当我运行时 或 具有该 ID 的初始容器将停止或删除,但新容器出现并运行。我试图使用以下命令更新容器: 然而,这没有帮助。 这里是'docker info'命令结果: 和“docker inspect[container_id]”
我有一个带有ASP.NET核心的docker容器和一个带有MySQL的容器。现在,我需要使用ASP.NET核心容器等待,mysql容器已经启动并准备就绪(这两个容器都是通过docker-compose.yml启动的)。 这是我的DockerFile:
我拉Ubuntu图像使用。 我使用连接到容器,然后创建一个文件,然后退出。 再次,当我执行docker exec文件丢失。 如何维护该容器中的文件,我尝试了dockerfile和标记docker图像,效果很好。 但是,有没有其他方法可以让docker容器中的文件保持更长的时间?
我在试着和孔在一起。我在AWS上运行这个。每当我停止服务器并启动它时,API和插件中的每个条目都会消失。所以在每次启动和停止之后,我必须重新添加api和插件的值。有人能告诉我如何保留数据吗? docker run-d--名为kong database-p9042:9042 cassandra:2.2然后我运行了kong docker run-d--名为kong--链接kong database:k