请教:关于 mkfifo 创建有名管道的权限问题

2014-07-15 07:45:20 +08:00
 initialdp
一个简单的C代码,使用mkfifo创建有名管道给其他应用,代码如下:
...
mkfifo("/tmp/myfifo", 0666 );
fd = open("/tmp/myfifo", O_NONBLOCK|O_RDWR);
...
创建成功了,可是权限并不是666,而是仍然只能本用户访问:
prw-r--r--

其他程序如果以其他用户身份写管道,则提示无权限。只有以同一个用户的身份运行的程序能成功写入。

如果改用mknod函数(据说这是老旧的处理方式),则可以成功设置为666(其他用户可读可写)。

系统是Debian7.5.

google了一下mkfifo函数,貌似大家都是这样的写法。是姿势不对么?

谢谢。
4420 次点击
所在节点    问与答
2 条回复
initialdp
2014-07-15 07:59:18 +08:00
搞定了,需要用umask先清除掉默认权限:
...
umask(0);
mkfifo("/tmp/myfifo", 0666 );
...

不过仍然不明白为什么要这样:不清除原来的,就不能设置新的? 不科学啊。
stevenyou
2014-07-15 08:15:32 +08:00
既然是mask那么所有subprocess生成的文件都要经过parent process 的mask, 你可以用chmod 去改啊

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/122653

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX