我查看了您的 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 "$@"