Опитвам се да централизирам изхода от 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