启动uWSGI实例失败,代码为203

时间:2017-09-16 18:31:21

标签: python ubuntu nginx flask uwsgi

我想在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

感谢您的帮助。

1 个答案:

答案 0 :(得分:1)

问题在于权限。您从数字海洋跟踪的指南缺少关键步骤 - nginx使用www-data组创建套接字,因此您需要将项目文件夹的所有权授予该组,并确保您正在执行的用户与此相关。

简单地说,运行这两个命令

chown -R sammy:www-data /home/sammy/<project>/*

usermod -aG www-data sammy