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

问题:

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

相关推荐
剑神一笑2 小时前
Linux pgrep 命令详解:按名称查找进程 PID 的高效方法
linux·运维·chrome
剑神一笑2 小时前
Linux killall 命令详解:按进程名批量终止进程的原理与实践
linux·运维·chrome
日取其半万世不竭6 小时前
iftop、nethogs 和 nload:Linux 服务器网络流量实时监控工具介绍
linux·运维·服务器
mounter6256 小时前
Linux 内核资源管理:控制组(cgroup)的演进与“策略组”新提案
linux·运维·服务器·cgroup·kernel
bksczm6 小时前
文件在磁盘中的存储方式
linux·运维·服务器
L1624766 小时前
OpenSSH 半自动升级方案(独立编译 + 手动迁移 + 重建 systemd 服务)
linux·服务器·ssh
半旧夜夏7 小时前
【保姆级】微服务组件环境搭建(Docker Compose版)
java·linux·spring cloud·微服务·云原生·容器
爱莉希雅&&&8 小时前
zabbix快速搭建和使用
android·linux·数据库·zabbix·监控
z200509308 小时前
【linux学习】深入理解linux文件I/O,从C标准库到内核态
linux·学习·操作系统
weixin_307779138 小时前
面向高性能保密计算的定制 Linux 系统构建与自动部署方案
linux·安全·网络安全·性能优化·系统安全