gpt4 book ai didi

linux - 读取命名管道时如何防止读取 block 退出

转载 作者:太空宇宙 更新时间:2023-11-04 10:10:12 25 4
gpt4 key购买 nike

我有一个 BASH 脚本,它在 NFS 安装的文件系统上跟踪文件并写入名为/tmp/t2 的管道。

#!/bin/bash
tail -f /mnt/cdr1/radius/calldatarecords | grep ^2 | awk -F, '{print $4","$13","$14","$15","$22","$23","$120","$140","$173}' | tr -d \" | tr - _ > /tmp/t2

挂载输出

# mount
v7000:/ibm/cdr-fs on /mnt/cdr1 type nfs (ro,relatime,vers=3,rsize=1048576,wsize=1048576,namlen=255,hard,proto=tcp,timeo=600,retrans=2,sec=sys,mountaddr=10.12.2.12,mountvers=3,mountport=32767,mountproto=udp,local_lock=none,addr=10.12.2.12,_netdev)

第二个脚本从阻塞的/tmp/t2 管道读取

#!/bin/bash
echo "connected to pipe"
while read CID DUR CST DCD EGR ING PDD SGL MST
do
echo Read Line at $(date +%s)
done < /tmp/t2
echo "what should never happen"

这已经在 Ub12.04 上运行了多年,只有很少的失败,然后在迁移到 Ub16.04 LTS 后开始频繁发生。最初编码时,当/mnt/cdr1/radius/calldatarecords 在晚上没有被一致地写入时,我看到了这种性质的东西。围绕失败的读取 block 的一段时间确实解决了当时大部分的问题,但它不再有效。不应该发生的事情在 16.04 上经常发生。我已经在 strace 下运行了两个脚本来捕捉正在发生的事情。第二个程序退出

write(1, "Read Line at 1522279814\n", 24Read Line at 1522279814
) = 24
ioctl(0, TCGETS, 0x7ffc48240330) = -1 ENOTTY (Inappropriate ioctl for device)
lseek(0, 0, SEEK_CUR) = -1 ESPIPE (Illegal seek)
read(0, "", 1) = 0
dup2(10, 0) = 0
fcntl(10, F_GETFD) = 0x1 (flags FD_CLOEXEC)
close(10) = 0
read(255, "echo \"this should never happen\"\n", 158) = 32
write(1, "this should never happen\n", 25this should never happen
) = 25
read(255, "", 158) = 0
rt_sigprocmask(SIG_BLOCK, [CHLD], [], 8) = 0
rt_sigprocmask(SIG_SETMASK, [], NULL, 8) = 0
exit_group(0) = ?
+++ exited with 0 +++

因此第一个脚本 strace 退出报告 SIGPIPE。或者反过来,考虑到我没有将此数据识别为调用数据记录的一部分。

...
read(5, "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0"..., 8192) = 4424
write(1, "\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0\0"..., 4096) = -1 EPIPE (Broken pipe)
--- SIGPIPE {si_signo=SIGPIPE, si_code=SI_USER, si_pid=12853, si_uid=0} ---
+++ killed by SIGPIPE +++

谁能解释为什么第二个程序异常退出,我该如何防止?任何帮助表示赞赏。感谢阅读。

最佳答案

尝试拖尾你的文件

tail --follow=name --retry

您可能需要按照说明调整 nfs 挂载 here .

关于linux - 读取命名管道时如何防止读取 block 退出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49545918/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com