正如教程所说,我在ubuntu16.04中用flask、uwsgi和nginx构建了一个项目,并得到了异常502 Bad Gateway。我检查了日志,发现.sock文件的访问权限被拒绝
日志上写着:
2018/07/24 12:38:24 [crit] 8805#8805: *1 connect() to unix:///home/mylegendarytime/final/final.sock failed (13: Permission denied) while connecting to upstream, client: 127.0.0.1, server: 127.0.0.1, request: "GET / HTTP/1.1", upstream: "uwsgi://unix:///home/mylegendarytime/final/final.sock:", host: "127.0.0.1"
和我的nginx设置:
server {
listen 80;
server_name 127.0.0.1;
location / {
include uwsgi_params;
uwsgi_pass unix:///home/mylegendarytime/final/final.sock;
}
}
我不知道是什么错误导致了这个错误。我试过
$ chmod 777 ~/final/final.sock
但没有改变
编辑:
这是我的uWSGI设置:
[uwsgi]
module = wsgi
master = true
processes = 5
socket = final.sock
chmod-socket = 660
vacuum = true
die-on-term = true
我试着把chmod插座换成777,但没用。
这是我的systemd-unix文件:
[Unit]
Description=uWSGI instance to serve final
After=network.target
[Service]
User=mylegendarytime
Group=www-data
WorkingDirectory=/home/mylegendarytime/final
Environment="PATH=/home/mylegendarytime/final/finalenv/bin"
ExecStart=/home/mylegendarytime/final/finalenv/bin/uwsgi --ini final.ini
[Install]
WantedBy=multi-user.target
所以我最终通过将用户更改为www数据来解决这个问题,因为nginx使用这个名称来使用socket。你可以在nginx.conf.上查看