我有一个使用 nginx 和 php-fpm 在 docker 中运行的服务。我一直在绞尽脑汁想让所有日志重定向到 stdout。我采取的方法是使用supervisord。使用docker-compose up my-app
一切工作正常;所有日志都被发送到 stdout。但是,当我运行
docker run -p 81:80 \
-v $(pwd)/myapp:/var/www/html \
my-app
我没有得到任何输出。
这是我的主管配置:
[supervisord]
nodaemon=true
user=root
[program:php-fpm]
command=/usr/sbin/php-fpm7.0 -F
[program:nginx]
command=/usr/sbin/nginx -g "daemon off;"
[program:nginx-log-access]
command=/usr/bin/tail -f /var/log/nginx/access.log
stdout_logfile=/dev/fd/1
stdout_logfile_maxbytes=0
autorestart=true
[program:nginx-log-error]
command=/usr/bin/tail -f /var/log/nginx/error.log
stdout_logfile=/dev/fd/1
stdout_logfile_maxbytes=0
autorestart=true
[program:php-fpm-log]
command=/usr/bin/tail -f /var/log/php7.0-fpm.log
stdout_logfile=/dev/fd/1
stdout_logfile_maxbytes=0
autorestart=true
startsecs=3
[program:laravel-log]
command=/usr/bin/tail -f /var/www/html/storage/logs/laravel.log
stdout_logfile=/dev/fd/1
stdout_logfile_maxbytes=0
autorestart=true
和我的docker-compose
version: '3'
services:
my-app:
build:
context: ../../my-app
dockerfile: docker/Dockerfile
image: my-app
ports:
- "81:80"
volumes:
- ../../my-app:/var/www/html
我的基本docker文件
FROM ubuntu
# Update
RUN apt-get update --fix-missing && apt-get -y upgrade
# Install Python Setup Tools
RUN apt-get install -y python-pip
# Intall Supervisord
RUN easy_install supervisor
# Install NGINX
RUN apt-get -y install nginx
# Install PHP
RUN apt-get -y install php7.0-fpm \
php7.0-mbstring \
php7.0-xml \
php7.0-curl
# Configure PHP-FPM
RUN sed -i 's/;daemonize = .*/daemonize = no/' /etc/php/7.0/fpm/php-fpm.conf && \
sed -i "/;clear_env = .*/c\clear_env = no" /etc/php/7.0/fpm/pool.d/www.conf && \
sed -i -e 's/max_execution_time = 30/max_execution_time = 300/g' /etc/php/7.0/fpm/php.ini && \
sed -i -e 's/upload_max_filesize = 2M/upload_max_filesize = 50M/g' /etc/php/7.0/fpm/php.ini && \
sed -i -e 's/post_max_size = 8M/post_max_size = 50M/g' /etc/php/7.0/fpm/php.ini && \
sed -i -e "s/variables_order = \"GPCS\"/variables_order = \"EGPCS\"/g" /etc/php/7.0/fpm/php.ini && \
service php7.0-fpm start && \
service php7.0-fpm stop
COPY supervisor.conf /etc/supervisor/conf.d/supervisor.conf
CMD ["supervisord", "-n", "-c", "/etc/supervisor/conf.d/supervisor.conf"]
和我的应用程序dockerfile
FROM mybase
# Configure NGINX
COPY docker/dev2/default.conf /etc/nginx/sites-enabled/default
# Copy application into container
COPY . /var/www/html
RUN touch /var/www/html/storage/logs/laravel.log && \
chown www-data:www-data /var/www/html/storage/logs/laravel.log && \
chmod 644 /var/www/html/storage/logs/laravel.log
COPY docker/dev2/supervisor.conf /etc/supervisor/conf.d/supervisor.conf
CMD ["supervisord", "-c", "/etc/supervisor/conf.d/supervisor.conf"]
docker
和之间有什么区别docker-compose
?重定向到 stdout 的行为有何不同?这些容器将部署在 AWS ECS 中;我还没有测试过,但如果我在 中遇到这种行为,我担心我将无法成功登录 ECS docker
。任何想法、意见或建议都将不胜感激!
答案1
当你运行docker-compose up
所有docker容器的输出时,它们会被聚合并显示在控制台中
https://docs.docker.com/compose/reference/up/
当您简单运行时,docker run
不会显示输出,只能使用以下方法检索docker logs -f $CONTAINERID
您还可以使用标志来“隐藏”docker compose的输出-d
。
在 ECS 中运行 Docker 容器时,在任务定义中,您可以从列表中选择日志驱动程序
http://docs.aws.amazon.com/AmazonECS/latest/APIReference/API_LogConfiguration.html
希望这可以帮助。