Я пытаюсь централизовать вывод из supervisord и его процессов, используя supervisor-stdout
. Но с этой конфигурацией супервизора:
#supervisord.conf
[supervisord]
nodaemon = true
[program:nginx]
command = /usr/sbin/nginx
stdout_events_enabled = true
stderr_events_enabled = true
[eventlistener:stdout]
command = supervisor_stdout
buffer_size = 100
events = PROCESS_LOG
result_handler = supervisor_stdout:event_handler
(Обратите внимание, что раздел конфигурации supervisor-stoud точно такой же, как и в примере на сайте supervisor-stoud. а>).
...и этот Dockerfile:
#Dockerfile
FROM python:3-onbuild
RUN apt-get update && apt-get install -y nginx supervisor
# Setup supervisord
RUN pip install supervisor-stdout
RUN mkdir -p /var/log/supervisor
COPY supervisord.conf /etc/supervisor/conf.d/supervisord.conf
COPY nginx.conf /etc/nginx/nginx.conf
# restart nginx to load the config
RUN service nginx stop
# Start processes
CMD supervisord -c /etc/supervisor/conf.d/supervisord.conf -n
Я могу создать образ просто отлично, но запуск из него контейнера дает мне:
Ошибка: supervisor_stdout:event_handler не может быть разрешен в [eventlistener:stdout]
ИЗМЕНИТЬ
Результат запуска:
supervisord -c /etc/supervisor/conf.d/supervisord.conf -n
is:
Error: supervisor_stdout:event_handler cannot be resolved within [eventlistener:stdout]
For help, use /usr/bin/supervisord -h
supervisord -c /etc/supervisor/conf.d/supervisord.conf -n
, когда вы запускаете его вручную в контейнере? Использование:docker exec <cid> /bin/bash
- person James Mills   schedule 22.04.2015supervisord -c /etc/supervisor/conf.d/supervisord.conf -n
- person Berco Beute   schedule 22.04.2015