ubuntu-除非root用户,否则uWSGI Emperor权限被拒绝

我试过使用二进制文件本身的标志(–uid www-data –gid www-data)并将其设置在我的配置中:

    uid = www-data
    gid = www-data

但是套接字始终是使用我正在使用的帐户生成的,所以我收到nginx的权限被拒绝错误.

有人知道为什么吗?

附加问题:有谁知道nginx和uwsgi在哪里设置了用户?我有另一台一直在工作的服务器,并且在任何配置文件中都没有设置uid或gid,但是一切都使用了www-data.

回答显然,如果您按照我的尝试从终端启动服务,即(user @ server:〜/ $uwsgi –uid www-data –gid www-data),它将始终与用户一起启动并运行谁叫它解释了为什么我觉得它没有遵守我的uid和gid标志.当我如下所述运行它时,它确实以正确的用户/组www-data运行.

更新

如您所说,我正在启动uWSGI,“ sudo服务uwsgi start”应该触发该文件(/etc/init/uwsgi.conf):

description "uWSGI"
start on runlevel [2345]
stop on runlevel [06]
respawn

env UWSGI=/home/ccadmin/.local/bin/uwsgi
env LOGTO=/var/log/uwsgi/emperor.log

exec $UWSGI --master --emperor /etc/uwsgi/vassals --die-on-term --uid www-data --gid www-data --logto $LOGTO

但是,使用此配置,我的emperor.log文件显示:

execvp(): Permission denied [core/emperor.c line 1481]
[emperor] binary path: /home/ccadmin/.local/bin/uwsgi
[emperor] is the uwsgi binary in your system PATH ?
TIME STAMP - [emperor] curse the uwsgi instance cc_uwsgi.ini (pid: ####)
TIME STAMP - [emperor] removed uwsgi instance cc_uwsgi.ini

如果我将–uid和–gid更改为root,则一切正常.它必须是一些简单的权限,但是对于linux来说是新手,我发现很难查明.

同样奇怪的是,它正在向我询问我的系统路径中的uwsgi二进制文件……应该存在吗?因为我已经将/home/ccadmin/.local/bin添加到/ etc / environment中的系统路径中.不应该在那里吗?还是应该一直到二进制文件? (即,将/home/ccadmin/.local/bin/uwsgi insetad仅添加到/ bin)

最佳答案
您应该以root用户身份启动uwsgi,否则,您将无法切换到其他用户.基本的Unix概念.通过sudo使用service uwsgi start命令.

相关文章

文章浏览阅读3.7k次,点赞2次,收藏5次。Nginx学习笔记一、N...
文章浏览阅读1.7w次,点赞14次,收藏61次。我们在使用容器的...
文章浏览阅读1.4k次。当用户在访问网站的过程中遇到404错误时...
文章浏览阅读2.7k次。docker 和 docker-compose 部署 nginx+...
文章浏览阅读1.3k次。5:再次启动nginx,可以正常启动,可以...
文章浏览阅读3.1w次,点赞105次,收藏182次。高性能:Nginx ...