今天,我使用appcontainers/ MediaWiki docker映像部署了一个MediaWiki实例,现在我遇到了一个新问题,我找不到任何线索。 在尝试使用以下方法附加到mediawiki前端容器后:

docker attach mediawiki_web_1

在我的配置上终止,原因我忽略了,也试着:

docker exec -it mediawiki_web_1 bash

我确实得到了一个接近错误的消息:

Error response from daemon: Container 81c07e4a69519c785b12ce4512a8ec76a10231ecfb30522e714b0ae53a0c9c68 is restarting, wait until the container is running

这就是我的新问题,因为这个容器从未停止重新启动。我可以看到,使用docker ps -a总是返回一个状态重启(127)x秒前。

问题是,我能够停止容器(我测试过),但再次启动它似乎将它带回到重新启动循环中。

知道问题出在哪里吗?整个东西都正常工作,直到我试图把它接上……

我很伤心:-(


当前回答

它正在重新启动,状态代码为127,这意味着在容器中有一个丢失的文件/库。启动一个新的容器可能会解决这个问题。

解释:

就我对Docker的理解而言,下面是正在发生的事情:

容器试图启动。在这个过程中,它尝试访问一个不存在的文件/库。 它以127的状态码退出,在这个答案中解释了这一点。 通常,这是容器应该完全退出的地方,但它会重新启动。 它会重新启动,因为重启策略必须被设置为不是no(默认值)的值(使用命令行标志——restart或docker-compose)。Yml键重启),同时启动容器。

解决方案:某些东西可能损坏了容器。理想情况下,启动一个新的容器就可以了。

其他回答

如果你创建了一个systemd服务,它有:

[Service]
Restart=always
ExecStart=/usr/bin/docker container start -a my_container
ExecStop=/usr/bin/docker container stop -t 2 my_container

我有这个问题,因为我在一个docker swarm尝试:

docker swarm leave --force

我忘记了Minikube在后台运行,这总是会重新启动它们

它正在重新启动,状态代码为127,这意味着在容器中有一个丢失的文件/库。启动一个新的容器可能会解决这个问题。

解释:

就我对Docker的理解而言,下面是正在发生的事情:

容器试图启动。在这个过程中,它尝试访问一个不存在的文件/库。 它以127的状态码退出,在这个答案中解释了这一点。 通常,这是容器应该完全退出的地方,但它会重新启动。 它会重新启动,因为重启策略必须被设置为不是no(默认值)的值(使用命令行标志——restart或docker-compose)。Yml键重启),同时启动容器。

解决方案:某些东西可能损坏了容器。理想情况下,启动一个新的容器就可以了。

docker logs命令将显示容器在非交互式运行时生成的输出。这很可能包括错误消息。

docker logs --tail 50 --follow --timestamps mediawiki_web_1

你也可以用docker run -ti <your_wiki_image>在前台运行一个新容器来看看它做了什么。您可能需要将docker-compose yml中的一些配置映射到docker命令。

我猜附加到媒体维基进程导致崩溃,破坏了数据中的某些东西。