Назад | Перейти на главную страницу

Ошибка привязки Docker, Nginx и Supervisor nginx

Я пытаюсь смонтировать готовый к работе сервер с помощью Nginx, Docker и Supervisor.

Проблема, с которой я столкнулся, заключается в том, что даже если он работает, и я вижу index.html в моем браузере, эта ошибка отображается все время: 2016/08/28 12:05:12 [emerg] 12#12: bind() to [::]:80 failed (98: Address in use) nginx: [emerg] bind() to [::]:80 failed (98: Address in use)

Докерфайл:

FROM nginx:stable-alpine

RUN rm -f /etc/nginx/conf.d/* && mkdir -p /var/www/app
COPY config/nginx.conf /etc/nginx/conf.d/
COPY config/supervisord.conf /supervisord.conf
COPY scripts /scripts
RUN chmod -R 700 /scripts

CMD [ "/scripts/start" ]

В / scripts / start у меня вот такое:

#!/bin/bash
supervisord -n -c /supervisord.conf

Затем в supervisord.conf:

[unix_http_server]
file=/dev/shm/supervisor.sock   ; (the path to the socket file)

[supervisord]
logfile=/tmp/supervisord.log ; (main log file;default $CWD/supervisord.log)
logfile_maxbytes=50MB        ; (max main logfile bytes b4 rotation;default 50MB)
logfile_backups=10           ; (num of main logfile rotation backups;default 10)
loglevel=info                ; (log level;default info; others: debug,warn,trace)
pidfile=/tmp/supervisord.pid ; (supervisord pidfile;default supervisord.pid)
nodaemon=false               ; (start in foreground if true;default false)
minfds=1024                  ; (min. avail startup file descriptors;default 1024)
minprocs=200                 ; (min. avail process descriptors;default 200)
user=root                    ;

[rpcinterface:supervisor]
supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface

[program:nginx]
command=/usr/sbin/nginx
autostart=true
autorestart=true
priority=10
stdout_events_enabled=true
stderr_events_enabled=true
stdout_logfile=/dev/stdout
stdout_logfile_maxbytes=0
stderr_logfile=/dev/stderr
stderr_logfile_maxbytes=0

И когда я запускаю docker (без опции daemon -d), я получаю следующий вывод терминала:

2016-08-28 12:05:10,474 CRIT Set uid to user 0
2016-08-28 12:05:10,481 INFO RPC interface 'supervisor' initialized
2016-08-28 12:05:10,481 CRIT Server 'unix_http_server' running without any HTTP authentication checking
2016-08-28 12:05:10,481 INFO supervisord started with pid 6
2016-08-28 12:05:11,484 INFO spawned: 'nginx' with pid 9
2016-08-28 12:05:11,497 INFO exited: nginx (exit status 0; not expected)
2016-08-28 12:05:12,499 INFO spawned: 'nginx' with pid 12
2016/08/28 12:05:12 [emerg] 12#12: bind() to 0.0.0.0:80 failed (98: Address in use)
nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address in use)
2016/08/28 12:05:12 [emerg] 12#12: bind() to [::]:80 failed (98: Address in use)
nginx: [emerg] bind() to [::]:80 failed (98: Address in use)
........

Похоже, что он породил 2 процесса nginx вместо одного, потому что сначала сказал, что он умер без причины, но на самом деле он не умер.

Здесь есть несколько проблем. Во-первых, обычно не рекомендуется запускать supervisord в контейнерах, если вы действительно не знаете, что делаете. Кроме того, убедитесь, что вы установили nodaemon в supervisord на true, иначе docker убьет ваш контейнер, потому что pid 1 больше не будет (поскольку он будет разветвляться).

То же самое и с nginx. Supervisord ожидает, что nginx не будет разветвляться, а останется на переднем плане. Отключите демон в файле конфигурации nginx.