一个目录拥有多个用户可访问权限

问题:

root@localhost \~# id nginx

uid=1003(nginx) gid=1003(nginx) groups=1003(nginx)

root@localhost \~# id mml3

uid=1002(mml3) gid=1002(mml3) groups=1002(mml3)

我要让/home/images这个目录,nginx用户和mml3用户都可以访问,该怎么做


答案

要使 nginx 用户和 mml3 用户都能访问 /home/images 这个目录,你需要确保以下几点:

  1. 目录权限:确保目录的权限允许所属组和其他用户访问。

  2. 用户组 :一个简单的方法是将 nginx 用户和 mml3 用户都添加到一个共同的组,并为此组设置对 /home/images 的访问权限。

以下是具体步骤:

  1. 创建一个新的组 :例如,我们可以创建一个名为 webaccess 的组。

    bash 复制代码
    sudo groupadd webaccess
  2. nginxmml3 用户都添加到 webaccess

    bash 复制代码
    sudo usermod -aG webaccess nginx
    sudo usermod -aG webaccess mml3
  3. 更改 /home/images 目录的组,并设置正确的权限:

    bash 复制代码
    sudo chown :webaccess /home/images
  4. 设置目录权限:你可能希望设置 775 权限,这样目录的所有者和组都有读、写和执行权限,而其他用户只有读和执行权限。

    bash 复制代码
    sudo chmod 775 /home/images
  5. 如果 /home/images 目录内有已经存在的文件和子目录,并且你希望它们也具有相同的权限和组设置,你可以递归地应用上述更改:

    bash 复制代码
    sudo chown -R :webaccess /home/images
    sudo chmod -R 775 /home/images

完成上述步骤后,nginxmml3 用户都应该能够访问 /home/images 目录了。

问题:

这个是sudo usermod -aG webaccess nginx

sudo usermod -aG webaccess mml3

修改还是增加


答案:

这两个命令:

bash 复制代码
sudo usermod -aG webaccess nginx
sudo usermod -aG webaccess mml3

是用来增加用户到一个已存在的组。

在这里,-aG 选项的意思是:

  • -a:表示 "append"(附加),意思是在不删除用户从属于其他任何组的情况下,将用户添加到指定组。
  • -G:指定组名。

所以,这两个命令的作用是将 nginxmml3 这两个用户添加到 webaccess 组,而不会影响他们属于其他的组。

相关推荐
A小辣椒16 小时前
TShark:Wireshark CLI 功能
linux
A小辣椒20 小时前
TShark:基础知识
linux
AlfredZhao1 天前
OCI 明明分配了 200G 系统盘,为什么 df 只看到 30G?
linux·oci
AlfredZhao2 天前
vi 删除指定范围的行,不用再反复按 dd
linux·vi
用户9718356334662 天前
银河麒麟 KY10 申威(SW64) 安装 nginx-1.16.1-2.p01.ky10.sw_64.rpm 详细步骤
linux
猪脚踏浪2 天前
linux 拷贝文件或目录到指定的位置
linux
摇滚侠3 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
bush43 天前
嵌入式linux学习记录十四、术语
linux·嵌入式
载数而行5203 天前
Linux 11 动态监控指令top
linux
不会C语言的男孩3 天前
Linux 系统编程 · 第 8 章:进程基础
linux·c语言