加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

bash:睡眠过程没有被杀

发布时间:2020-12-15 21:18:59 所属栏目:安全 来源:网络整理
导读:参见英文答案 What’s the best way to send a signal to all members of a process group?????????????????????????????????????32个 我写了一个简单的bash脚本,除了睡觉之外什么都不做. #!/bin/bashecho "Sleeping..."sleep 180s 运行脚本后,我看到我的系
参见英文答案 > What’s the best way to send a signal to all members of a process group?????????????????????????????????????32个
我写了一个简单的bash脚本,除了睡觉之外什么都不做.

#!/bin/bash

echo "Sleeping..."
sleep 180s

运行脚本后,我看到我的系统上运行了两个进程:

user 22880  0.0  0.0  12428  1412 pts/28   S+   20:12   0:00 /bin/bash ./sleep.sh
user 22881  0.0  0.0   7196   356 pts/28   S+   20:12   0:00 sleep 180s

我使用kill -15 22880将IDTERM提供给id为22880的进程,这会杀死进程.但是,在此之后,我仍然看到180秒后退出的sleep命令正在运行.

user 22881  0.0  0.0   7196   356 pts/28   S    20:12   0:00 sleep 180s

为什么会这样?如果不让睡眠180s进程运行,我需要做什么?

解决方法

kill -15 22880会向执行脚本的shell发送信号,但不会向sleep命令发送信号.要将信号发送到进程组中的每个进程,您应该能够指定负进程ID.

kill -15 -22880

或者,确保脚本在退出之前杀死其子项.

trap 'kill $(jobs -p)' EXIT
echo "Sleeping..."
sleep 180s & wait

如果在接收到信号时将睡眠置于前台,则shell必须等到它退出才能运行陷阱;睡眠是不间断的.解决方法是在后台运行它,然后等待它.等待,作为内置的shell,可以被中断,以便陷阱立即运行并杀死仍在进行中的任何后台进程.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读