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

问题:

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 组,而不会影响他们属于其他的组。

相关推荐
AlfredZhao12 小时前
Docker 容器时区不对,`timedatectl` 不存在怎么办?
linux·timezone
zzzzzz3102 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
XIAOHEZIcode2 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
A小辣椒4 天前
TShark:Wireshark CLI 功能
linux
A小辣椒4 天前
TShark:基础知识
linux
AlfredZhao4 天前
OCI 明明分配了 200G 系统盘,为什么 df 只看到 30G?
linux·oci
AlfredZhao5 天前
vi 删除指定范围的行,不用再反复按 dd
linux·vi
用户9718356334665 天前
银河麒麟 KY10 申威(SW64) 安装 nginx-1.16.1-2.p01.ky10.sw_64.rpm 详细步骤
linux
猪脚踏浪5 天前
linux 拷贝文件或目录到指定的位置
linux
摇滚侠6 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql