当前位置: 首页 > 知识库问答 >
问题:

Docker容器将在"docker run-d"后自动停止

司徒元明
2023-03-14

根据我目前阅读的教程,使用“dockerrun-d”将从图像启动一个容器,容器将在后台运行。这就是它的样子,我们可以看到我们已经有了容器id。

root@docker:/home/root# docker run -d centos
605e3928cdddb844526bab691af51d0c9262e0a1fc3d41de3f59be1a58e1bd1d

但如果我运行“docker ps”,则不会返回任何内容。

所以我尝试了“docker ps-a”,我可以看到容器已经退出:

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

我做错了什么吗?如何解决此问题?

共有3个答案

宦书
2023-03-14

Docker容器运行使其保持活动状态的进程(“命令”或“入口点”)。只要命令继续运行,容器就会继续运行。

在您的情况下,命令(/bin/bash,默认情况下,在centos:latest上)将立即退出(bash未连接到终端且无需运行时也会退出)。

通常,当您以守护程序模式(使用-d)运行容器时,该容器正在运行某种守护程序进程(如nicpd)。在这种情况下,只要http pd守护进程在运行,容器就会保持活动状态。

您似乎试图做的是在容器内没有运行守护进程的情况下保持容器的活动状态。这有点奇怪(因为在与容器交互之前,容器没有做任何有用的事情,可能是与docker exec),但在某些情况下,这样做可能是有意义的。

(你是想在容器内看到bash提示符吗?这很简单!docker run-it centos:latest

在守护进程模式下保持容器无限期活动的一种简单方法是作为容器的命令运行sleep infinity。这并不依赖于做一些奇怪的事情,比如在守护进程模式下分配TTY。尽管它确实依赖于做一些奇怪的事情,比如使用sleep作为主要命令。

$ docker run -d centos:latest sleep infinity
$ docker ps
CONTAINER ID  IMAGE         COMMAND          CREATED       STATUS       PORTS NAMES
d651c7a9e0ad  centos:latest "sleep infinity" 2 seconds ago Up 2 seconds       nervous_visvesvaraya

正如cjsimon所指出的,-t选项分配了一个伪tty。这会使bash无限期地继续运行,因为它认为它连接到交互式TTY(即使如果不传递-i,您无法与该特定TTY进行交互)。不管怎样,这应该也能做到:

$ docker run -t -d centos:latest

无法100%确定-t是否会产生其他奇怪的交互;如果有,也许会在下面留下评论。

谭琛
2023-03-14

根据这个答案,添加-t标志将防止容器在后台运行时退出。然后可以使用docker exec-i-t

docker run -t -d <image> <command>

虽然帮助中说-t选项“分配了一个伪TTY,”,但它似乎没有很好的文档化

穆高澹
2023-03-14

centos dockerfile有一个默认命令bash

这意味着,当在后台(-d)运行时,shell会立即退出。

2017年更新

docker的最新版本授权在分离模式和前台模式下运行容器(-t-i-it

在这种情况下,您不需要任何其他命令,这就足够了:

docker run -t -d centos

bash将在后台等待<卡拉尼·乔达里(kalyani chaudhari)的回答中最初报告了这一点,泽西比恩(jersey bean)的回答中对此进行了详细说明。

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

注意,对于阿尔卑斯山,马里诺群岛在评论中报告:

docker run-t-d alpine/git无法保持进程正常运行
不得不做:docker run--entrypoint”/bin/sh“-it-alpine/git

原始答复(2015年)

如本文所述:

建议使用-d,而不是使用docker run-i-t image运行您的命令,因为您只需一个命令就可以运行您的容器,并且不需要通过点击CtrlPQ来分离容器的终端。

但是,-d选项有问题。容器立即停止,除非命令在前台继续运行。
Docker要求命令在前台继续运行。否则,它认为您的应用程序停止并关闭容器。

问题是某些应用程序不在前台运行。我们怎样才能使它更容易?

在这种情况下,可以将tail-f/dev/null添加到命令中
通过这样做,即使主命令在后台运行,容器也不会停止,因为tail会继续在前台运行。

因此,这将起作用:

docker run -d centos tail -f /dev/null

或者在Dockerfile中:

ENTRYPOINT ["tail"]
CMD ["-f","/dev/null"]

一个docker ps将显示centos容器仍在运行。

从那里,您可以附加到它或从它分离(或docker exec一些命令)。

 类似资料:
  • 问题内容: 根据我到目前为止阅读的教程,使用“ ”将从图像启动容器,并且该容器将在后台运行。看起来是这样,我们可以看到我们已经有了容器ID。 但是如果我运行“ ”,则什么也没有返回。 所以我尝试了“ ”,可以看到容器已经退出: 我做错了什么?如何解决此问题? 问题答案: 在CentOS的dockerfile有一个默认的命令。 这意味着,在后台()中运行时,外壳程序会立即退出。 更新2017 最近泊

  • 根据我到目前为止阅读的教程,使用“”将从图像启动一个容器,并且容器将在后台运行。这是看起来的样子,我们可以看到我们已经有了容器ID。 我做错什么了吗?如何解决此问题?

  • 我在官方docker网站上遵循了“开始”教程,一切都很顺利,直到我尝试删除容器。每次当我运行时 或 具有该 ID 的初始容器将停止或删除,但新容器出现并运行。我试图使用以下命令更新容器: 然而,这没有帮助。 这里是'docker info'命令结果: 和“docker inspect[container_id]”

  • 我拉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

  • 问题内容: 我正在使用Search Guard插件来保护由多个节点组成的elasticsearch集群。这是我的Dockerfile: 初始化SearchGuard(创建内部用户并分配角色)。容器启动后,我需要运行脚本。这是问题所在:除非运行Elasticsearch,否则脚本将不会初始化任何安全性索引。 脚本的内容是: 现在,我只是在容器启动后手动运行脚本,但是由于我是在Kubernetes上运