免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2163 | 回复: 8

[系统管理] bg进程创建后ps查看没有此进程 [复制链接]

论坛徽章:
9
每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00数据库技术版块每周发帖之星
日期:2016-03-07 16:30:25
发表于 2013-01-07 14:18 |显示全部楼层
本帖最后由 cenalulu 于 2013-01-07 14:19 编辑

后台运行的命令发起后,立即用ps aux查看进程,会有一定概率找不到这个进程。
这个是什么原理?
如下代码,运行一段时间后,会有 xxx not found in processlist 的文字打出
  1. #! /bin/sh

  2. while [[ 1 ]]
  3. do
  4.                 yes >/dev/null 2>&1 &
  5.                 PID=$!
  6.                 if [[ `ps aux|grep $PID|grep yes|wc -l` -eq 0 ]]
  7.                 then
  8.                                 echo "$PID not found in processlist";
  9.                 fi               
  10.                 kill -9 $PID;
  11. done
复制代码
个人理解是不是ps维护的只是系统内部进程的缓存列表,如果查询比缓存刷新来的快就看不到最新的进程状态了?

论坛徽章:
3
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:51:162015年亚洲杯之阿曼
日期:2015-04-07 20:00:59
发表于 2013-01-07 18:48 |显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
1
射手座
日期:2014-03-10 14:24:52
发表于 2013-01-07 19:08 |显示全部楼层
不理解。回头看看高手解答。

论坛徽章:
9
每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00数据库技术版块每周发帖之星
日期:2016-03-07 16:30:25
发表于 2013-01-08 09:47 |显示全部楼层
回复 2# zooyo


    最先是写了个脚本调用tcpdump 放到后台抓包,然后拿到PID,用ps aux判断这个PID是否存在,存在的话sleep 5s 然后kill掉。
然后这个脚本就会偶尔出现上面的情况,就是ps 没有成功发现tcpdump的存在,导致kill没有触发。最终导致tcpdump进程就一直跑下去了。

功能已经通过其他方式解决了,目前就是对于这个现象的困惑:
1. 为什么是偶发的?
2. 为什么会发生?

论坛徽章:
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
发表于 2013-01-08 10:28 |显示全部楼层
用ps aux判断这个PID是否存在,存在的话sleep 5s 然后kill掉。

sleep 5s之后直接kill就行了
典型的包子问题

论坛徽章:
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
发表于 2013-01-08 10:30 |显示全部楼层
抛开包子问题
if [[ `ps aux|grep $PID|grep yes|wc -l` -eq 0 ]]
还是
if [ `ps aux|grep $PID|grep yes|wc -l` -eq 0 ]  ?

论坛徽章:
9
每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00数据库技术版块每周发帖之星
日期:2016-03-07 16:30:25
发表于 2013-01-08 11:03 |显示全部楼层
回复 6# waker


    查阅了下man, [ 和 [[ 区别只是前者是externel program 后者是keyword,也改写了上面的脚本测试了下,并没有实质上的改变,仍然会有偶发的PID找不到。
目前功能上的问题已经通过其他方式实现了。只是比较好奇为什么 ps 看不到一个已经在运行的PID ,想了解下内部原理。
还麻烦waker答疑解惑一下?

论坛徽章:
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
发表于 2013-01-08 11:18 |显示全部楼层
我觉得是脚本的问题或是解释器的问题

论坛徽章:
1
巳蛇
日期:2013-10-28 15:55:33
发表于 2013-01-08 15:56 |显示全部楼层
还是
[ -d /proc/$PID ]
好!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP