bash – 检查命名管道/ FIFO是否打开以进行写入
发布时间:2020-12-15 22:58:24 所属栏目:安全 来源:网络整理
导读:我为其他进程写入了一个命名管道,并希望检查其他进程是否正确启动,但是不知道它的PID.上下文是 running a command in screen,确保命令正确启动.我希望这可行: mkfifo /tmp/fooecho hello /tmp/foo lsof /tmp/foo 可悲的是,lsof没有报告回声. inotifywait可
我为其他进程写入了一个命名管道,并希望检查其他进程是否正确启动,但是不知道它的PID.上下文是
running a command in screen,确保命令正确启动.我希望这可行:
mkfifo /tmp/foo echo hello > /tmp/foo & lsof /tmp/foo 可悲的是,lsof没有报告回声. inotifywait可能是另一个选项,但并不总是安装,我真的只想轮询一次,而不是阻止直到某个事件. 有没有办法检查命名管道是否打开写入?一般都开放吗? 更新: 一旦两端连接lsof似乎工作.这实际上解决了我的问题,但是为了这个问题,我有兴趣知道是否有可能在没有阅读器的情况下检测到命名管道的初始重定向. > mkfifo /tmp/foo > yes > /tmp/foo & > lsof /tmp/foo > cat /tmp/foo > /dev/null & > lsof /tmp/foo COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME yes 16915 user 1w FIFO 8,18 0t0 16660270 /tmp/foo cat 16950 user 3r FIFO 8,18 0t0 16660270 /tmp/foo 解决方法
更新2:使用inotify-tools后,似乎没有办法获得已经打开命名管道进行写入并阻塞的通知.这可能就是为什么lsof在有读者和作者之前不显示管道的原因.
更新:在研究命名管道之后,我不相信有任何方法可以自己使用命名管道. >无法限制命名管道的写入者数量(无需求助于锁定) 您可以尝试使用短暂超时向管道写入任何内容.如果超时到期,则写入被阻止,表明有人已经打开了管道进行写入. 注意:正如评论中所指出的,如果读者存在并且可能足够快,我们的测试写入将不会阻止,测试基本上会失败.注释下面的猫线来测试这个. #!/bin/bash is_named_pipe_already_opened_for_writing() { local named_pipe="$1" # Make sure it's a named pipe if ! [ -p "$named_pipe" ]; then return 1 fi # Try to write zero bytes in the background echo -n > "$named_pipe" & pid=$! # Wait a short amount of time sleep 0.1 # Kill the background process. If kill succeeds,then # the write was blocked indicating that someone # else is already writing to the named pipe. kill $pid 2>/dev/null } PIPE=/tmp/foo # Ignore any bash messages from killing below trap : TERM mkfifo $PIPE # a writer yes > $PIPE & # a reader cat $PIPE >/dev/null & if is_named_pipe_already_opened_for_writing "$PIPE"; then echo "$PIPE is already being written to by another process" else echo "$PIPE is NOT being written to by another process" fi jobs -pr | kill 2>/dev/null rm -f $PIPE (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容