免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2870 | 回复: 4
打印 上一主题 下一主题

脚本中捕获信号,在管道参与时失效 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-08-28 22:19 |只看该作者 |倒序浏览
我需要在脚本中处理信号,按照标准的方法处理没有问题,脚本如下:

#!/bin/sh

# sig.sh

signal_handle()
{
    echo "Got a signal"
}

trap signal_handle SIGHUP SIGINT SIGQUIT SIGPIPE SIGTERM

while true
do
    echo "wait for signal"
    sleep 1
done

这个脚本单独运行没有问题,但是如果将输出传入管道,信号就不能被捕获了。如下面的命令

sh sig.sh 2>&1 | tee log

请问是什么原因,有没有办法解决。谢谢

[ 本帖最后由 Largem 于 2009-8-28 22:20 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2009-08-29 09:59 |只看该作者
信号捕获仍然起作用, 原因是:

你肯定是通过按键来发送信号的, 如SIGINT .. 此时tee接收到了信号而中断, 而后sh sig.sh 收到SIGPIPE信号, 该信号被捕捉后企图向管道输出Got a signal, 由于管道已经关闭(tee消失了), 就会出现类似  echo: write error: Broken pipe 这样的错误, 所以你感觉好像信号捕获失效. 如果你不捕获SIGPIPE, 此时sh sig.sh由于收到SIGPIPE也会中断, 给你的感觉也是SIGINT捕获失效

如果使用kill确保SIGINT信号发送给sh sig.sh 进程 (而不是tee进程), 那么信号捕获的效果就如预期了.

论坛徽章:
0
3 [报告]
发表于 2009-08-30 08:18 |只看该作者
非常感谢,有一些进展了,我确实用按键发信号的,ctrl-c

如果按照如下的调用:
sh sig.sh | tee log
确实收到了信号,也出现了Broken pipe.

如果加上了2>&1, 信号就完全没有了。

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
4 [报告]
发表于 2009-08-31 08:18 |只看该作者

回复 #3 Largem 的帖子

Broken pipe这个消息也想输出到已经破裂的管道

论坛徽章:
0
5 [报告]
发表于 2009-08-31 23:12 |只看该作者

回复 #4 waker 的帖子

没看懂你回复的意思。我已经trap SIGPIPE了,但是并没有截获到,如果有2>&1的话。命令如下

sh sig.sh 2>&1 | tee log

如果没有2>&1,管道消息是被处理了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP