Django uwsgi celery daemonization с несколькими проектами виртуальных сред на одном сервере - PullRequest
0 голосов
/ 04 мая 2019

Возможно ли запустить несколько рабочих из сельдерея для различных проектов виртуальных сред с attach-daemon2 из uwsgi? В конфигурационные файлы .ini uwsgi каждого проекта я добавил одного и того же демона. Всего одна работа.

/ и т.д. / uwsgi / приложение доступное / proj1.ini

[uwsgi]
virtualenv=/var/apps/proj1.com
processes=4
chdir=/var/apps/proj1.com
socket=/tmp/proj1.ini.socket
workers=32
chmod-socket=666
touch-reload=./uwsgi_reload
module=theapp.wsgi:application
cheaper=2
cheaper-initial=2
idle=300
cheaper-step=1
env=LC_ALL=es_ES.UTF-8
plugins=python35
threads=2
attach-daemon2 = stopsignal=13,reloadsignal=13,cmd=bin/celery multi start w_%n --app=theapp --concurrency=1 --schedule=/var/run/celery/%n_celerybeat-schedule --pidfile=/var/run/celery/%n_celery.pid --loglevel=ERROR --logfile=/var/log/celery/%n.log --beat

/ и т.д. / uwsgi / приложение доступное / proj2.ini

[uwsgi]
virtualenv=/var/apps/proj2.com
processes=4
chdir=/var/apps/proj2.com
socket=/tmp/proj2.ini.socket
workers=32
chmod-socket=666
touch-reload=./uwsgi_reload
module=theapp.wsgi:application
cheaper=2
cheaper-initial=2
idle=300
cheaper-step=1
env=LC_ALL=es_ES.UTF-8
plugins=python35
threads=2
attach-daemon2 = stopsignal=13,reloadsignal=13,cmd=bin/celery multi start w_%n --app=theapp --concurrency=1 --schedule=/var/run/celery/%n_celerybeat-schedule --pidfile=/var/run/celery/%n_celery.pid --loglevel=ERROR --logfile=/var/log/celery/%n.log --beat

/ вар / приложения / proj1.com / theapp / settings.py

WSGI_APPLICATION = 'theapp.wsgi.application'

# CELERY
BROKER_URL = 'redis://localhost:6379/0'
CELERY_RESULT_BACKEND = 'redis://localhost:6379/0'
CACHES = {
    'default': {
        "BACKEND": "redis_cache.RedisCache",
        "LOCATION": "redis://127.0.0.1:6379/0",
    }
}

/ вар / приложения / proj2.com / theapp / settings.py

WSGI_APPLICATION = 'theapp.wsgi.application'

# CELERY
BROKER_URL = 'redis://localhost:6379/1'
CELERY_RESULT_BACKEND = 'redis://localhost:6379/1'
CACHES = {
    'default': {
        "BACKEND": "redis_cache.RedisCache",
        "LOCATION": "redis://127.0.0.1:6379/1",
    }
}
...