如何解决在生产环境中运行python manage.py run_huey
我最近使用Ubuntu 20.04,gunicorn和nginx部署了一个django网络应用程序,并实现了Huey,该应用程序在本地完美运行。在生产中,我需要使用systemd运行python manage.py run_huey 。
我在Can't enable huey service on deploy server处尝试过该建议,但是没有用。
我的代码类似于该建议。我将不胜感激。预先感谢
解决方法
我可以通过在代码中添加 Requires = gunicorn.socket 来解决此问题。现在我的huey.service看起来很
[Unit]
Description=Huey Service
Requires=gunicorn.socket
After=redis.service
[Service]
User=deploy
Group=www-data
WorkingDirectory=/home/username/projectdir
ExecStart=/home/username/projectdir/env/bin/python manage.py run_huey
Restart=always
[Install]
WantedBy=multi-user.target
之后,我运行sudo systemctl启动gunicorn.sock。工作正常,但显示为active:dead,我不喜欢
,我最终用主管来经营休伊 我把supervisord.conf / home / user。看起来像这样
[unix_http_server]
file=/tmp/supervisor.sock ; the path to the socket file
chmod=0700 ; socket file mode (default 0700)
chown=user:user ; socket file uid:gid owner
[supervisord]
logfile=/home/user/supervisord.log ; main log file; default $CWD/supervisord.log
logfile_maxbytes=1MB ; max main logfile bytes b4 rotation; default 50MB
logfile_backups=5 ; # of main logfile backups; 0 means none,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
silent=false ; no logs to stdout if true; default false
minfds=1024 ; min. avail startup file descriptors; default 1024
minprocs=200 ; min. avail process descriptors;default 200
childlogdir=/home/medsjoin ; 'AUTO' child log dir,default $TEMP
[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:huey]
command=python manage.py run_huey ; the program (relative uses PATH,can take args)
directory=/home/user/projectdir; directory to cwd to before exec (def no cwd)
autostart=true ; start at supervisord start (default: true)
redirect_stderr=true ; redirect proc stderr to stdout (default false)
stdout_logfile_maxbytes=1MB ; max # logfile bytes b4 rotation (default 50MB)
stdout_logfile_backups=2 ; # of stdout logfile backups (0 means none,default 10)
stderr_logfile_maxbytes=1MB ; max # logfile bytes b4 rotation (default 50MB)
stderr_logfile_backups=2 ; # of stderr logfile backups (0 means none,default 10)
environment =
DJANGO_SETTINGS_MODULE="special.settings",PYTHONPATH="/home/user/projectdir/special",PATH="/home/user/projectdir/env/bin:%(ENV_PATH)s"
我从/etc/systemd/system/supervisord.service中的supervisord.service开始
[Unit]
Description=supervisord daemon
Documentation=http://supervisord.org
After=network.target
[Service]
ExecStart=/usr/local/bin/supervisord -n -c /home/user/supervisord.conf
ExecReload=/usr/local/bin/supervisorctl -c /home/user/supervisord.conf reload
ExecStop=/usr/local/bin/supervisorctl -c /home/user/supervisord.conf shutdown
[Install]
WantedBy=multi-user.target
然后使用来启动服务
sudo systemctl start supervisord.service
通过以下方式检查状态
sudo systemctl status supervisord.service
您可能还需要运行
sudo systemctl enable supervisord
请注意用户代表我的用户projectdir:django项目所在的位置,项目:my django项目
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。