我想在Ubunut 16.04上使用nginx和uWSGI部署我的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
感谢您的帮助。
答案 0 :(得分:1)
问题在于权限。您从数字海洋跟踪的指南缺少关键步骤 - nginx使用www-data组创建套接字,因此您需要将项目文件夹的所有权授予该组,并确保您正在执行的用户与此相关。
简单地说,运行这两个命令
chown -R sammy:www-data /home/sammy/<project>/*
usermod -aG www-data sammy