当用户属于目录组时无权创建子目录

当用户属于目录组时无权创建子目录

给定一个目录 DirA (目录所有者是root且组是sys)。
给定一个用户 userA,该用户属于 sys 组,他应该能够在 DirA 内创建一个子目录?

在 Solaris SunOS 5.9 上我有一个目录/opt

bash-2.05$ ls -la /
total 1205
drwxr-xr-x  34 root     root        1024 Mar 17 04:21 .
drwxr-xr-x  34 root     root        1024 Mar 17 04:21 ..
.. Removed all..
lrwxrwxrwx   1 root     other         16 Apr 14  2008 opt -> /export/home/opt

这个符号链接将我带到:

bash-2.05$ ls -la /export/home
total 524638
drwxr-xr-x  31 root     root        1024 Jan 25  2015 .
drwxr-xr-x   3 root     sys          512 Jul  2  2007 ..
...REMOVED...
drwxr-xr-x  12 root     sys          512 Apr 24 10:29 opt

我使用用户生成器登录:

bash-2.05$ /usr/ucb/whoami
builder

他属于以下群体:

bash-2.05$ groups builder
other root sys 
bash-2.05$

那么为什么mkdir会失败呢/opt/

bash-2.05$ cd /opt/
bash-2.05$ pwd
/opt
bash-2.05$ mkdir mynewdir
mkdir: Failed to make directory "mynewdir"; Permission denied
bash-2.05$ cd /export/home/opt/
bash-2.05$ mkdir mynewdir
mkdir: Failed to make directory "mynewdir"; Permission denied
bash-2.05$

答案1

drwxr-xr-x  12 root     sys          512 Apr 24 10:29 opt

意味着该目录只能写入root。为了使sys组成员能够更改目录(包括创建子目录),需要

drwxrwxr-x  12 root     sys          512 Apr 24 10:29 opt

如果您想启用此功能:

chmod g+w opt

会做出适当的改变。

相关内容