Я пытаюсь смонтировать готовый к работе сервер с помощью 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.