AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 524738
Accepted
Kenneth Hanson
Kenneth Hanson
Asked: 2019-06-14 10:24:57 +0800 CST2019-06-14 10:24:57 +0800 CST 2019-06-14 10:24:57 +0800 CST

为什么选择 002 而不是 022 的 umask?

  • 772

今天我正在清理我的家庭系统上的组和权限,并重新熟悉了 umasks。我的系统(Ubuntu 18.10)上的默认值似乎是 002,但对于 root,它是 0022。

忽略当前目的的额外位,这让我思考。使用默认值 002,与我的用户名关联的组中的任何用户都可以编辑我的文件。使用 022,他们不会。现在,我以前从未使用过这个组(也没有使用过 root 的组),所以我不知道为什么有人会使用它,也不知道在这种情况下哪些权限是合适的。

原则上,您为什么会选择其中一个选项而不是另一个选项?对于加分,为什么(这部分)root的umask和普通用户不一样?

permissions umask
  • 1 1 个回答
  • 4819 Views

1 个回答

  • Voted
  1. Best Answer
    ilkkachu
    2019-06-14T12:09:33+08:002019-06-14T12:09:33+08:00

    使用默认值 002,与我的用户名关联的组中的任何用户都可以编辑我的文件。

    这个想法并不是用户的个人组中会有其他用户。这个想法是可能有项目组等,并且他们可能有多个用户作为成员。然后文件的组所有者可以是项目(不是任何用户个人),由项目目录上的setgid强制执行。使用 umask 允许对组进行写访问,这样的文件将可由项目组的所有成员写入。

    它的工作原理是这样的,假设foo是一个使用 umask 的用户002:

    # [将用户 foo 添加到 proj 组]
    # mkdir /work/proj
    # chmod u=rwx,g=rwx,o=,g+s /work/proj
    # ls -ld /work/proj
    drwxrws--- 2 根项目 4096 Jun 14 17:48 /work/proj/
    $ 掩码
    0002
    $ cd /工作/项目
    $ echo "这里有一些数据" > file.txt
    $ ls -l 文件.txt
    -rw-rw-r-- 1 foo proj 15 Jun 14 17:51 file.txt
    

    请注意文件是如何创建的 a) 具有组所有者proj(因为目录上的setgid),以及 b) 具有对整个组的写权限(因为 umask)。可以使用默认 ACL设置目录,而不是要求用户具有正确的 umask,如果设置了 umask,它会替换 umask 的功能。

    至少在这里和Red Hat 的手册中有更多关于每个用户组和 umask 的内容(这是 RHEL 4 的手册,较新的手册似乎对此事更简短。)这个问题也相关:为什么每个用户都有他们的自己的组?


    这里没有任何东西可以防止用户手动弄乱权限。这是无法阻止的,因为文件所有者可以随时更改他们认为合适的权限。现在人们也更多地使用网络服务进行协作,而这种具有文件和目录权限的体操是没有必要的。

    • 2

相关问题

  • 组权限如何工作?

  • Redis日志文件权限错误,但是权限已经是777

  • 以 root 权限启动 zypper 命令

  • 以非特权用户身份运行时,meld 无法访问 /dev/fd/* 的可能原因是什么?

  • 另一个用户的非空子目录是否可以安全地从我的目录中删除?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve