我想使用nginx和uWSGI在Ubunut 16.04上部署Flask应用程序,但是每当我执行sudo systemctl启动nebulon时,我都不会收到错误消息,但是状态显示以下内容:
nebulon.service - uWSGI instance to serve nebulon
Loaded: loaded (/etc/systemd/system/nebulon.service; enabled; vendor preset: enabled)
Active: failed (Result: exit-code) since Sat 2017-09-16 18:08:35 UTC; 5s ago
Process: 18718 ExecStart=/nebulonapp/nebulon.sock --ini /nebulonapp/nebulon.ini (code=exited, status=203/EXEC)
Main PID: 18718 (code=exited, status=203/EXEC)
nebulon.service:
[Unit]
Description=uWSGI instance to serve nebulon
After=network.target
[Service]
User=nebulonuser
Group=www-data
WorkingDirectory=/nebulonapp
ExecStart=/nebulonapp/nebulon.sock --ini /nebulonapp/nebulon.ini
[Install]
WantedBy=multi-user.target
在
/nebulonapp
中,我有nebulon.ini:[uwsgi]
chdir=/nebulonapp/
wsgi-file = wsgi.py
callable = app
plugin=python35
master = true
processes = 5
socket = nebulon.sock
chmod-socket = 666
vacuum = true
die-on-term = true
nebulon.sock
在/nebulonapp
中,但为空。 uWSGI的状态如下:uwsgi.service - LSB: Start/stop uWSGI server instance(s)
Loaded: loaded (/etc/init.d/uwsgi; bad; vendor preset: enabled)
Active: active (exited) since Sat 2017-09-16 18:22:53 UTC; 10s ago
Docs: man:systemd-sysv-generator(8)
Process: 18828 ExecStop=/etc/init.d/uwsgi stop (code=exited, status=0/SUCCESS)
Process: 18854 ExecStart=/etc/init.d/uwsgi start (code=exited, status=0/SUCCESS)
Sep 16 18:22:53 nebulon systemd[1]: Stopped LSB: Start/stop uWSGI server instance(s).
Sep 16 18:22:53 nebulon systemd[1]: Starting LSB: Start/stop uWSGI server instance(s)...
Sep 16 18:22:53 nebulon uwsgi[18854]: * Starting app server(s) uwsgi
Sep 16 18:22:53 nebulon uwsgi[18854]: ...done.
Sep 16 18:22:53 nebulon systemd[1]: Started LSB: Start/stop uWSGI server instance(s).
尽管可以使用以下命令测试uWSGI。
uwsgi --socket 0.0.0.0:5000 --plugin-python3 --protocol=http -w wsgi:app
谢谢你的帮助。
最佳答案
问题在于权限。您从数字海洋中获得的指南缺少关键的步骤-nginx使用www-data组创建套接字,因此您需要将项目文件夹的所有权授予该组,并确保您正在执行的用户与是其中的一部分。
只需运行这两个命令chown -R sammy:www-data /home/sammy/<project>/*
usermod -aG www-data sammy
关于python - 启动uWSGI实例失败,代码为203,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/46257171/