V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
initialdp
V2EX  ›  问与答

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

  •  1
     
  •   initialdp · 2014-07-15 07:45:20 +08:00 · 4433 次点击
    这是一个创建于 3809 天前的主题,其中的信息可能已经有所发展或是发生改变。
    一个简单的C代码,使用mkfifo创建有名管道给其他应用,代码如下:
    ...
    mkfifo("/tmp/myfifo", 0666 );
    fd = open("/tmp/myfifo", O_NONBLOCK|O_RDWR);
    ...
    创建成功了,可是权限并不是666,而是仍然只能本用户访问:
    prw-r--r--

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

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

    系统是Debian7.5.

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

    谢谢。
    2 条回复    2014-07-15 08:15:32 +08:00
    initialdp
        1
    initialdp  
    OP
       2014-07-15 07:59:18 +08:00
    搞定了,需要用umask先清除掉默认权限:
    ...
    umask(0);
    mkfifo("/tmp/myfifo", 0666 );
    ...

    不过仍然不明白为什么要这样:不清除原来的,就不能设置新的? 不科学啊。
    stevenyou
        2
    stevenyou  
       2014-07-15 08:15:32 +08:00
    既然是mask那么所有subprocess生成的文件都要经过parent process 的mask, 你可以用chmod 去改啊
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3137 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 29ms · UTC 13:29 · PVG 21:29 · LAX 05:29 · JFK 08:29
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.