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 / 问题 / 459432
Accepted
derobert
derobert
Asked: 2018-07-31 11:22:09 +0800 CST2018-07-31 11:22:09 +0800 CST 2018-07-31 11:22:09 +0800 CST

为什么目录上的 chmod g+s 被忽略?

  • 772

我有一个要共享的 git(实际上是 git-annex)存储库,其中一部分涉及在多个目录上设置 set-group-id 位。这是在 Debian GNU/Linux Stretch 盒子上,在 ext4 文件系统上。由于某些奇怪的原因,chmod g+s DIRECTORY被忽略(chmod为便于阅读,块周围添加了空白行):

$ stat objects
  File: objects
  Size: 4096            Blocks: 8          IO Block: 4096   directory
Device: fd06h/64774d    Inode: 12353692    Links: 260
Access: (0775/drwxrwxr-x)  Uid: ( 1000/ anthony)   Gid: ( 1025/git-books)
Access: 2018-07-30 14:43:13.831641743 -0400
Modify: 2018-07-28 14:28:14.970667931 -0400
Change: 2018-07-30 14:46:38.179597449 -0400
 Birth: -

$ chmod g+s objects
$ echo $?
0

$ stat objects
  File: objects
  Size: 4096            Blocks: 8          IO Block: 4096   directory
Device: fd06h/64774d    Inode: 12353692    Links: 260
Access: (0775/drwxrwxr-x)  Uid: ( 1000/ anthony)   Gid: ( 1025/git-books)
Access: 2018-07-30 14:43:13.831641743 -0400
Modify: 2018-07-28 14:28:14.970667931 -0400
Change: 2018-07-30 14:50:43.355539381 -0400
 Birth: -

到目前为止我检查过的内容:

  • 似乎没有任何奇怪的挂载选项(例如,nosuid)可能会阻止它工作。我检查了 fstab 和/proc/mounts,它显示/dev/mapper/slow-srv /srv ext4 rw,relatime,nobarrier,errors=remount-ro,stripe=384,data=ordered 0 0
  • 目录上似乎没有任何奇怪的 ACL;可以肯定的是我做到了setfacl -b objects。即使这样做了, chmod 仍然无法正常工作。
  • straceonchmod显示系统调用成功,并且设置了 sgid 位:
    fchmodat(AT_FDCWD, "annex", 02775) = 0
  • 同一文件系统上的其他目录设置了 set-group-id 位。事实上,我在同一个会话的前面设置了一些,在不同的 git-annex 存储库中。
files permissions
  • 1 1 个回答
  • 2395 Views

1 个回答

  • Voted
  1. Best Answer
    derobert
    2018-07-31T11:22:09+08:002018-07-31T11:22:09+08:00

    事实证明,虽然我在几天前创建了该组并将自己添加到其中,而且我认为这是一个新的 ssh 连接,但事实并非如此。由于使用了 OpenSSH 的连接多路复用功能 ( ControlMaster/ ControlPath/etc.),我实际上是在一个大约 10 天前的连接上登录的,所以我的会话(进程)没有设置新的组。我用 确认了这一点id。

    通过 登录后ssh -o ControlPath=none HOST,id确认我的会话有git-books组,并且chmod g+s工作。

    至于为什么没有给出权限被拒绝错误,似乎标准要求文件具有这种行为并允许实现忽略这些位:

    如果调用进程没有适当的权限,并且文件的组 ID 与有效组 ID 或补充组 ID 之一不匹配,并且如果文件是常规文件,则位 S_ISGID (set-group-ID on从 chmod() 成功返回后,文件模式下的执行)将被清除。

    其他实现定义的限制可能会导致模式中的 S_ISUID 和 S_ISGID 位被忽略。

    单一 Unix Spec v4 2018 版, chmod 。http://pubs.opengroup.org/onlinepubs/9699919799/functions/chmod.html(可能需要注册)。

    可能,返回错误只是理智的,而不是一致的☹。

    • 3

相关问题

  • 删除文件名后缀最小的文件

  • 列出根据特定内容行排序的文件

  • 如何提前知道 .zip 内部是否有父目录

  • 如何找到特定的文件类型并将它们 tar?

  • du/df 和 ls 报告不同的磁盘使用情况

Sidebar

Stats

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

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

    • 4 个回答
  • Marko Smith

    ssh 无法协商:“找不到匹配的密码”,正在拒绝 cbc

    • 4 个回答
  • Marko Smith

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

    • 5 个回答
  • Marko Smith

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

    • 3 个回答
  • Marko Smith

    如何卸载内核模块“nvidia-drm”?

    • 13 个回答
  • 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
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add 返回:“连接代理时出错:没有这样的文件或目录” 2018-08-24 23:28:13 +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
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +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