У меня проблемы с запуском цветка с помощью супервайзера.
Следующая команда в моей среде разработки работает на консоли
celery --app=celery_conf.celeryapp flower --conf=flowerconfig
но переходя к производству, чтобы использовать супервизор, я получаю всевозможные ошибки
/supervisor/conf.d/flower.conf
[program:flower]
command=/opt/apps/venv/my_app/bin/celery flower --app=celery_conf.celeryapp --conf=flowerconfig
directory=/opt/apps/my_app
user=www-data
autostart=true
autorestart=false
redirect_stderr=true
stderr_logfile=/var/log/celery/flower.err.log
stdout_logfile=/var/log/celery/flower.out.log
С приведенной выше конфигурацией ошибки нет, но все, что делает сельдерей, - это помогает мне в выводе. Как будто он не признает переданные переменные.
Type 'celery <command> --help' for help using a specific command.
Usage: celery <command> [options]
Show help screen and exit.
Options:
-A APP, --app=APP app instance to use (e.g. module.attr_name)
-b BROKER, --broker=BROKER
url to broker. default is 'amqp://guest@localhost//'
--loader=LOADER name of custom loader class to use.
etc..
etc..
etc...
Супервайзер, с другой стороны, бросает INFO exited: flower (exit status 64; not expected)
У меня есть другие приложения, инициированные руководителем, использующие celery_beat
и использующие образцы файлов конфигурации github, и они хорошо работают с теми же путями к каталогам, что и выше.
Конфигурация цветка выглядит следующим образом:
flowerconfig.py
# Broker settings
BROKER_URL = 'amqp://guest:guest@localhost:5672//'
# RabbitMQ management api
broker_api = 'http://guest:guest@localhost:15672/api/'
#Port
port = 5555
# Enable debug logging
logging = 'INFO'
Решение:
Ну, на самом деле это не решение, поэтому я не назвал это ответом. Оказалось, что была проблема с моей виртуальной средой. Поэтому я удалил цветок и снова установил его, используя pip3.4, как на python3.4.
Однако следует отметить, что для того, чтобы цветок мог использовать ваш файл flowerconfig
, вам необходимо добавить запись director=/path/to/your/celery_config/folder/
в файл /etc/supervisor/conf.d/flower.conf
супервизора, иначе цветок запустится с настройками по умолчанию.
/etc/supervisor/conf.d/flower.conf
; ==================================
; Flower: For monitoring Celery
; ==================================
[program:flower]
command=/opt/apps/venv/my_app/bin/celery flower --app=celery_conf.celeryapp --conf=flowerconfig
directory=/opt/apps/my_app/celery_conf #this is key as my configuration file was in the `celery_conf` folder
user=www-data
autostart=true
autorestart=false
redirect_stderr=true
stderr_logfile=/var/log/celery/flower.err.log
stdout_logfile=/var/log/celery/flower.out.log
Спасибо.