问一个 Linux 的权限问题

2018-06-16 17:33:54 +08:00
 shaojz2005
Linux 使用 lnmp 作为服务器环境,创建站点时,会使用 www:www 作为目录的创建用户;如果我希望让别人登录服务器去管理文件,但不希望给他 root 权限,应该怎么做?

因为 www:www 是 lnmp 创建的用户,好像是没有用户目录的,也不能作为登录用户使用。我试过创建另外一个用户,放在 www 用户组里,并且设置网站目录的权限为所在组可读写。但如果别人通过这个用户来登录 Linux,他所创建的文件会属于当前用户,而不是 www,这就不太方便管理了。

我是否要想办法把 www 用户设置为可登录用户?
3012 次点击
所在节点    Linux
17 条回复
a7a2
2018-06-16 17:47:00 +08:00
'所创建的文件会属于当前用户,而不是 www',这样是正确的,本来这个目录就是其他用户可写的话文件当然记录为其他用户,否则才叫无迹可查。其他 nginx、php 之类设置为组可执行即可。
shaojz2005
2018-06-16 17:49:52 +08:00
可以让 www 用户变为可登录吗?
20has
2018-06-16 18:17:53 +08:00
useradd --help can help u!
20has
2018-06-16 18:18:19 +08:00
还有 sudo 了解一下,哈哈哈哈
likuku
2018-06-16 18:20:30 +08:00
FACL 了解下,这个能满足你需求。

同一个文件 /目录,可递归给不同用户授予不同权限。
afpro
2018-06-16 18:22:20 +08:00
@shaojz2005 www 用户不可以登陆不正是这个用户产生的原因之一吗?
artandlol
2018-06-16 18:28:39 +08:00
很简单,把代码设置成 770 即对 www 组下的用户完全控制, 再创建个账户,账户为组 www
qiongyue
2018-06-16 18:30:32 +08:00
首先作为程序文件,不一定非得是 www 用户所有才行,只要保证个别需要有写权限的目录赋与 www 写权限就好了,这样也更安全。

其实真要两个用户能同时维护一个目录,设置好目录的组权限不可以解决问题?
artandlol
2018-06-16 18:31:48 +08:00
usermod -s /bin/bash www 这样就能登陆了
omph
2018-06-16 18:35:38 +08:00
还有 acl 可以设权限,比系统的灵活很多
要么就开 ftp 或者 samba 服务器来远程管理文件,这样都不用给他系统帐号
plko345
2018-06-16 18:38:40 +08:00
特殊权限 guid,可以让其它用户在该目录下创建的文件的组为该目录的所属组
duola
2018-06-16 19:13:08 +08:00
先登录 root 管理,执行下面命令

passwd www

usermod -s /bin/bash www
nosay
2018-06-16 19:17:57 +08:00
我感觉除了一些特殊的目录,比如说缓存和日志目录,其余的所属人和组就不应该给 www.给一个可登录的普通用户就好
shaojz2005
2018-06-16 23:19:18 +08:00
谢谢,回来看到一堆回复真感动
msg7086
2018-06-17 03:16:42 +08:00
如果这个网站是设计成其他人管理的,那么应该让网站属于这个人的账号(账号可以是一个共享的集体账号)。比如某个网站应该由账号 devteam 来管理,那么整个目录可以归给 devteam,然后把 www 账号加入 devteam 组,PHP pool 之类的也可以设置成以 devteam 用户权限运行。
nicevar
2018-06-17 08:39:13 +08:00
其实最方便的办法是直接通过 ftp 账号来管理,其次添加一个用户对该网站目录有读写权限, 用 usermod 处理
Lwf1995
2018-06-22 15:24:54 +08:00
如果我没有记错的话 www 用户是 nginx 或者 php 的进程的从属用户,在这些 nginx 或者 php 的配置文件的开头有写出来的,你可以修改这个用户,或者从属组就可以了

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/463615

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX