#python #docker #docker-compose #celery #supervisord
#python #docker #docker-compose #сельдерей #супервизор
Вопрос:
пожалуйста, проверьте ОБНОВЛЕНИЯ ниже
я еще не видел ни одного рабочего примера конфигурации супервизора 3, поэтому в супервизоре 3 нет полезного документа, и поэтому здесь я ищу помощь
у меня следующая конфигурация супервизора
[unix_http_server]
file=/tmp/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 ;
; the below section must remain in the config file for RPC
; (supervisorctl/web interface) to work, additional interfaces may be
; added by defining them in separate rpcinterface: sections
[rpcinterface:supervisor]
supervisor.rpcinterface_factory = supervisor.rpcinterface:make_main_rpcinterface
[supervisorctl]
serverurl=unix:///tmp/supervisor.sock ; use a unix:// URL for a unix socket
[program:uvicorn]
command = uvicorn --host 0.0.0.0 --port 5000 app.app:app
autostart=true
autorestart=true
priority=5
stdout_events_enabled=true
stderr_events_enabled=true
stdout_logfile=/dev/stdout
stdout_logfile_maxbytes=0
stderr_logfile=/dev/stderr
stderr_logfile_maxbytes=0
[program:celery-worker]
command=celery -A app.app:celery worker -l info
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
[program:celery-beat]
command=celery -A app.app:celery beat -l info
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
и я запускаю супервизор со следующей командой
/usr/bin/supervisord -n -c /etc/supervisor/conf.d/supervisord.conf
вот что я вижу в запущенных процессах
# ps aux
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
root 1 0.0 0.1 5488 3072 ? Ss 05:41 0:00 /bin/bash entrypoint.test.sh
root 6 0.0 1.0 26996 20960 ? S 05:41 0:01 /usr/bin/python2 /usr/bin/supervisord -n -c /etc/supervisor/conf.d/supervisord.conf
root 9 0.7 1.7 115232 34672 ? Sl 05:41 0:11 /usr/local/bin/python /usr/local/bin/uvicorn --host 0.0.0.0 --port 5000 app.app:app
root 10 0.4 2.3 56344 48520 ? S 05:41 0:07 /usr/local/bin/python /usr/local/bin/celery -A app.app:celery worker -l info
root 11 0.0 2.2 54684 46380 ? S 05:41 0:01 /usr/local/bin/python /usr/local/bin/celery -A app.app:celery beat -l info
root 15 0.0 1.8 53724 37328 ? S 05:41 0:00 /usr/local/bin/python /usr/local/bin/celery -A app.app:celery worker -l info
root 16 0.0 1.8 53728 37180 ? S 05:41 0:00 /usr/local/bin/python /usr/local/bin/celery -A app.app:celery worker -l info
root 28 0.1 0.1 5752 3600 pts/0 Ss 06:06 0:00 bash
root 34 0.0 0.1 9392 3048 pts/0 R 06:06 0:00 ps aux
как вы можете видеть, это работает supervisor 2
с python2
, но какие изменения мне внести в файл конфигурации супервизора для использования supervisor 3
с python3?
Спасибо
Обновить:
супервизор был установлен в образе docker с apt-get install supervisor
нужно ли мне делать pip install supervisor
вместо этого? не уверен, может ли это быть проблемой здесь
# pip -V
pip 20.2.4 from /usr/local/lib/python3.8/site-packages/pip (python 3.8)
# python -V
Python 3.8.3
# pip freeze
amqp==5.0.2
billiard==3.6.3.0
celery==5.0.2
click==7.1.2
click-didyoumean==0.0.3
click-repl==0.1.6
fastapi==0.61.2
h11==0.11.0
kombu==5.0.2
prompt-toolkit==3.0.8
pydantic==1.7.2
pytz==2020.4
redis==3.5.3
six==1.15.0
starlette==0.13.6
uvicorn==0.12.2
vine==5.0.0
wcwidth==0.2.5
полезная ссылка о супервизоре 2-3
http://supervisord.org/upgrading.html
наконец, установите также pip install supervisor
и получите тот же супервизор 2
# pip freeze
amqp==5.0.2
billiard==3.6.3.0
celery==5.0.2
click==7.1.2
click-didyoumean==0.0.3
click-repl==0.1.6
fastapi==0.61.2
h11==0.11.0
kombu==5.0.2
prompt-toolkit==3.0.8
pydantic==1.7.2
pytz==2020.4
redis==3.5.3
six==1.15.0
starlette==0.13.6
supervisor==4.2.1
uvicorn==0.12.2
vine==5.0.0
wcwidth==0.2.5
Проблема связана с пакетом apt-get для Debian 10, который является базовой ОС для базового образа docker на python 3, который я использую, поставляется с supervisor 3.3.5
, а не с последней версией supervisor 4.2.1, так что, похоже, именно
в этом проблема
File "/usr/local/lib/python3.8/site-packages/pkg_resources/__init__.py", line 787, in resolve raise DistributionNotFound(req, requirers)
pkg_resources.DistributionNotFound: The 'supervisor==3.3.5' distribution was not found and is required by the application
и из репозитория supervisor github
Супервизор предназначен для работы на Python 3 версии 3.4 или более поздней и на Python 2 версии 2.7.
итак, все, что находится ниже supervisor 3.4, будет использовать python 2
Поэтому нужно найти способ установить пакет операционной системы supervisor из исходного кода
Комментарии:
1. Вы удаляете celery и переустанавливаете его для Python 3:
python3 -m pip install celery
2. что вы имеете в виду? celery работает в python3… используемый базовый образ docker — python3 … не уверен, что вы имеете в виду… также супервизор — это то, что работает с python2, а не с сельдереем
3. Это вопрос Python или вопрос версии супервизора? Я не понимаю, какое отношение версия Python должна иметь к синтаксису файла конфигурации супервизора.
4. прочитайте вопрос.. будь то python или supervisor.. какое это имеет значение? все, что я хочу, это чтобы супервизор работал с python3… просто прочитайте вопрос и не беспокойтесь о метке того, о каком теге идет речь
5. То же самое относится и к супервизору. Вам необходимо переустановить его для Python 3. Но если вы использовали дистрибутивный пакет, было бы неплохо остаться с Python 2.
Ответ №1:
Проблема связана с пакетом apt-get для Debian 10, который является базовой ОС для базового образа docker на python 3, который я использую, поставляется с supervisor 3.3.5, а не с последней версией supervisor 4.2.1, так что, похоже, именно в этом проблема
# cat /etc/*release
PRETTY_NAME="Debian GNU/Linux 10 (buster)"
NAME="Debian GNU/Linux"
VERSION_ID="10"
VERSION="10 (buster)"
VERSION_CODENAME=buster
ID=debian
HOME_URL="https://www.debian.org/"
SUPPORT_URL="https://www.debian.org/support"
BUG_REPORT_URL="https://bugs.debian.org/"
# apt-cache show supervisor
Package: supervisor
Version: 3.3.5-1
Installed-Size: 1447
Maintainer: Python Applications Packaging Team <python-apps-team@lists.alioth.debian.org>
Architecture: all
Depends: lsb-base, python-pkg-resources, python-meld3, python:any (<< 2.8), python:any (>= 2.7~)
Suggests: supervisor-doc
Description: System for controlling process state
Description-md5: 965223e7558e3d49e112406ca88bda2b
Homepage: http://supervisord.org/
Tag: implemented-in::python, role::program
Section: admin
Priority: optional
Filename: pool/main/s/supervisor/supervisor_3.3.5-1_all.deb
Size: 284260
MD5sum: 4a40c0ed0774b8b43c5645967129eeb1
SHA256: 9f68f3559eac10840d54301d56cca6ba8f7e202398b2f24bbf8e71a2a59785cb
и вот ошибка, которую я получаю
File "/usr/local/lib/python3.8/site-packages/pkg_resources/__init__.py", line 787, in resolve raise DistributionNotFound(req, requirers)
pkg_resources.DistributionNotFound: The 'supervisor==3.3.5' distribution was not found and is required by the application
и из репозитория supervisor github
https://github.com/Supervisor/supervisor#supported-platforms
Супервизор предназначен для работы на Python 3 версии 3.4 или более поздней и на Python 2 версии 2.7.
итак, все, что находится ниже supervisor 3.4, будет использовать python 2
Поэтому нужно найти способ установить пакет операционной системы supervisor из исходного кода
ИСПРАВЛЕНИЕ: я обновил базовый образ python docker для использования python:alpine
, который поставляется с supervisor 4.2.0
/ # apk add supervisor
(1/9) Installing python3 (3.8.5-r0)
(2/9) Installing py3-meld3 (2.0.1-r0)
(3/9) Installing py3-ordered-set (4.0.1-r0)
(4/9) Installing py3-appdirs (1.4.4-r1)
(5/9) Installing py3-parsing (2.4.7-r0)
(6/9) Installing py3-six (1.15.0-r0)
(7/9) Installing py3-packaging (20.4-r0)
(8/9) Installing py3-setuptools (47.0.0-r0)
(9/9) Installing supervisor (4.2.0-r0)
Executing busybox-1.31.1-r16.trigger
OK: 63 MiB in 44 packages
и вот мы идем
# ps aux
PID USER TIME COMMAND
1 root 0:00 /bin/sh entrypoint.alpine.sh
6 root 0:00 {supervisord} /usr/bin/python3 /usr/bin/supervisord -n -c /etc/supervisord.conf
8 root 0:01 {uvicorn} /usr/local/bin/python /usr/local/bin/uvicorn --host 0.0.0.0 --port 5000 app.app:app
9 root 0:00 {celery} /usr/local/bin/python /usr/local/bin/celery -A app.app:celery beat -l info
10 root 0:01 {celery} /usr/local/bin/python /usr/local/bin/celery -A app.app:celery worker -l info
12 root 0:00 {celery} /usr/local/bin/python /usr/local/bin/celery -A app.app:celery worker -l info
13 root 0:00 {celery} /usr/local/bin/python /usr/local/bin/celery -A app.app:celery worker -l info
21 root 0:00 sh
27 root 0:00 ps aux
ГОТОВО!!!