8

我已经构建了一个 Docker 映像,然后使用 Docker Compose 运行了一个容器。以下命令将为我完成这项工作:

docker-compose up -d

我已经重新启动了 PC,现在我想启动我之前创建的上一个容器。所以我尝试了以下命令:

$ docker-compose start 
Starting php-apache ... done

显然它可以工作,但它不符合以下命令的输出:

$ docker-compose ps
          Name                         Command               State    Ports 
---------------------------------------------------------------------------
php55devwork_php-apache_1   /bin/sh -c bash -C '/usr/l ...   Exit 0        

肯定有问题,我正在尝试找出问题所在。

  • 如何找到命令失败的原因?
  • 是否有任何地方可以看到日志文件或帮助我识别和修复错误的东西?

如果您想尝试一下,这里是存储库。

更新

如果我删除容器:docker rm <container-id>并通过docker-compose up -d --build再次运行它来重新创建它。

更新#1

我看不到这样奇怪的字符:

在此处输入图像描述

4

4 回答 4

16

这是帮助我解决此问题的原因:在 docker-compose yaml 文件中的一项服务下,键入以下内容:

tty: true所以它看起来像

version: '3'

services: 
   web: 
     tty: true

希望这可以帮助某人;如果它对您有帮助,请重振旗鼓:)

于 2018-06-22T13:31:42.123 回答
4

我查看了您的 Docker github 并setup_php_settings 在线(第 27 行)有source /etc/apache2/envvars && exec /usr/sbin/apache2 -DFOREGROUND

并且apache2在前台运行,因此它不应该以 status 退出code 0

但在我看来,您似乎setup_php_settings包含一些奇怪的字符(当我使用 compose 运行您的图像时) (原来是右侧的一个) 奇怪的字符 我已将其更改为新行,它对我有用。让我们知道它是否有帮助。

如果你想调试你的 docker 容器,你可以在没有入口点的情况下运行它,例如:

docker run -it yourImage bash


——经过一番调查:

当我重新启动 docker 容器时仍然存在一些错误 - 例如在您的情况下停止容器并在重新启动后启动。有问题:符号链接已经存在并且 apache2 有脾气暴躁的 PID,所以我们需要在官方 php docker中做一些类似的事情

setup_php_settings容器重启后,这对我来说完全有效。

#!/bin/bash -x
set -e

PHP_ERROR_REPORTING=${PHP_ERROR_REPORTING:-"E_ALL & ~E_DEPRECATED & ~E_NOTICE"}
sed -ri 's/^display_errors\s*=\s*Off/display_errors = On/g' /etc/php5/apache2/php.ini
sed -ri 's/^display_errors\s*=\s*Off/display_errors = On/g' /etc/php5/cli/php.ini
sed -ri "s/^error_reporting\s*=.*$//g" /etc/php5/apache2/php.ini
sed -ri "s/^error_reporting\s*=.*$//g" /etc/php5/cli/php.ini
echo "error_reporting = $PHP_ERROR_REPORTING" >> /etc/php5/apache2/php.ini
echo "error_reporting = $PHP_ERROR_REPORTING" >> /etc/php5/cli/php.ini

mkdir -p /data/tmp/php/uploads
mkdir -p /data/tmp/php/sessions
mkdir -p /data/tmp/php/xdebug

chown -R www-data:www-data /data/tmp/php*

ln -sf /etc/php5/mods-available/zz-php.ini /etc/php5/apache2/conf.d/zz-php.ini
ln -sf /etc/php5/mods-available/zz-php-directories.ini /etc/php5/apache2/conf.d/zz-php-directories.ini

# Add symbolic link to get Zend out of the current install dir
ln -sf /usr/share/php/libzend-framework-php/Zend/ /usr/share/php/Zend

a2enmod rewrite
php5enmod mcrypt

# Apache gets grumpy about PID files pre-existing
: "${APACHE_PID_FILE:=${APACHE_RUN_DIR:=/var/run/apache2}/apache2.pid}"
rm -f "$APACHE_PID_FILE"

source /etc/apache2/envvars && exec /usr/sbin/apache2 -DFOREGROUND "$@"
于 2016-10-18T18:57:39.980 回答
2

您可以使用 . 检查日志docker compose logs

浏览你的回购,你有

ENTRYPOINT bash -C '/usr/local/bin/setup_php_settings';'bash'

在没有交互式会话的情况下,bash 将在读取 stdin 上的文件末尾后立即退出(退出代码为 0)。

于 2016-10-18T18:29:55.970 回答
2

通常得到一个exit 0应该是庆祝的理由,因为它表明你的命令已经成功结束(http://www.tldp.org/LDP/abs/html/exit-status.html)。

看看你的Dockerfile样子,你只是bash在你的入口点调用,然后肯定会退出(因为它是非阻塞的)。为了提供一些数据,您应该调用php(这是一个保持容器运行的阻塞操作),就像在官方 docker 文件中为 php 所做的那样(CMD ["php", "-a"]参见https://github.com/docker-library/ php/blob/1c56325a69718a3e3cf76179e75d070b7e23da62/5.6/Dockerfile )

于 2016-10-18T18:18:52.907 回答