如何安全地设置 unix 域套接字的组所有权?

How to securely set the group ownership of a unix domain socket?

我想创建一个仅限于特定组的 Unix 域套接字。所以我最理想的做法是(忽略错误检查)像这样:

// Set the "address" (ie filesystem path)
struct sockaddr_un addr;
memset(&addr, 0, sizeof(addr));
addr.sun_family = AF_UNIX;
strcpy(addr.sun_path, "./my.sock");

int fd = socket(AF_UNIX, SOCK_DGRAM, 0);  // create the socket

// Set the group owner and permissions
fchmod(fd, 0770); // This seems to succeed
fchown(fd, -1, wanted_group_id);  // Silently fails

// Create the filesystem entry
bind(fd, (struct sockaddr *)&addr, sizeof(addr));

然而,fchown 在套接字 has no effect 上,因此似乎 chown 之后是设置组的唯一方法。我想避免让不应允许访问它的进程临时访问套接字。

我最好的想法是:

int fd = socket(...);
fchmod(fd, 0700);  // Remove group permissions
bind(fd, ...);     // Create fs entry
chown("./my.sock", -1, wanted_group_id); // set the correct group owner
fchmod(fd, 0770);  // And restore group permissions

对于 Unix 套接字来说,这当然是一件很常见的事情,并且有一种规范的方法可以实现这一点,但我还没有找到任何明确的答案。

我只对 Linux 感兴趣,但是对仅依赖于 POSIX 的东西加分。

这样做的方法是将套接字放入具有正确权限的目录中。目录可以自动创建(或重命名到位),一旦目录存在,套接字本身的权限就不是很重要。这也适用于 Unixes,其中套接字本身的权限并不总是受到尊重。