免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 3045 | 回复: 13

[Linux] 怎么跟踪不知道什么时候会执行一下的进程 [复制链接]

论坛徽章:
0
发表于 2013-08-27 23:01 |显示全部楼层
比如在脚本里有很多命令,其中有一个命令是cmd1,如何追踪这个命令cmd1呢,我想知道他执行时带的参数

论坛徽章:
17
处女座
日期:2013-08-27 09:59:352015亚冠之柏太阳神
日期:2015-07-30 10:16:402015亚冠之萨济拖拉机
日期:2015-07-29 18:58:182015年亚洲杯之巴勒斯坦
日期:2015-03-06 17:38:17摩羯座
日期:2014-12-11 21:31:34戌狗
日期:2014-07-20 20:57:32子鼠
日期:2014-05-15 16:25:21亥猪
日期:2014-02-11 17:32:05丑牛
日期:2014-01-20 15:45:51丑牛
日期:2013-10-22 11:12:56双子座
日期:2013-10-18 16:28:17白羊座
日期:2013-10-18 10:50:45
发表于 2013-08-28 10:53 |显示全部楼层
回复 1# chzht001

 获取命令的参数有多数方式,以下是其中三种

   1,cat /proc/进程号/cmdline 可以看到相应进程的命令和参数,你可以通过这个查看。
   2, 用命令 ps -p 进程号 -o args=
 3, 用命令 ps -C cmd1 -o args=

论坛徽章:
0
发表于 2013-08-29 10:03 |显示全部楼层
它这个要看脚本里面的某一条命令, myworkstation的不太好使。

论坛徽章:
17
处女座
日期:2013-08-27 09:59:352015亚冠之柏太阳神
日期:2015-07-30 10:16:402015亚冠之萨济拖拉机
日期:2015-07-29 18:58:182015年亚洲杯之巴勒斯坦
日期:2015-03-06 17:38:17摩羯座
日期:2014-12-11 21:31:34戌狗
日期:2014-07-20 20:57:32子鼠
日期:2014-05-15 16:25:21亥猪
日期:2014-02-11 17:32:05丑牛
日期:2014-01-20 15:45:51丑牛
日期:2013-10-22 11:12:56双子座
日期:2013-10-18 16:28:17白羊座
日期:2013-10-18 10:50:45
发表于 2013-08-29 10:25 |显示全部楼层
bash -x 脚本 &>file.log 这个终极大杀器想看啥执行都行。

论坛徽章:
0
发表于 2013-08-29 15:07 |显示全部楼层
呵呵,这个要顶。 或者自己写个包裹命令。

论坛徽章:
7
天蝎座
日期:2013-09-28 10:45:42双子座
日期:2013-10-16 16:27:09射手座
日期:2013-10-23 10:21:32处女座
日期:2014-09-17 16:44:332015年亚洲杯之巴林
日期:2015-04-09 17:28:01冥斗士
日期:2015-11-26 16:19:0015-16赛季CBA联赛之山东
日期:2018-03-02 23:59:31
发表于 2013-08-30 14:41 |显示全部楼层
回复 2# myworkstation

请问ps 的-o还有多少种格式? man不到。

只看到了
    Print only the process IDs of syslogd:
          ps -C syslogd -o pid=

       Print only the name of PID 42:
          ps -p 42 -o comm=


   

论坛徽章:
17
处女座
日期:2013-08-27 09:59:352015亚冠之柏太阳神
日期:2015-07-30 10:16:402015亚冠之萨济拖拉机
日期:2015-07-29 18:58:182015年亚洲杯之巴勒斯坦
日期:2015-03-06 17:38:17摩羯座
日期:2014-12-11 21:31:34戌狗
日期:2014-07-20 20:57:32子鼠
日期:2014-05-15 16:25:21亥猪
日期:2014-02-11 17:32:05丑牛
日期:2014-01-20 15:45:51丑牛
日期:2013-10-22 11:12:56双子座
日期:2013-10-18 16:28:17白羊座
日期:2013-10-18 10:50:45
发表于 2013-08-30 14:50 |显示全部楼层
本帖最后由 myworkstation 于 2013-08-30 14:50 编辑

回复 6# cxytz01


    有两种格式名称,AIX FORMAT和STANDARD FORMAT

AIX FORMAT:
       CODE   NORMAL   HEADER
       %C     pcpu     %CPU
       %G     group    GROUP
       %P     ppid     PPID
       %U     user     USER
       %a     args     COMMAND
       %c     comm     COMMAND
       %g     rgroup   RGROUP
       %n     nice     NI
       %p     pid      PID
       %r     pgid     PGID
       %t     etime    ELAPSED
       %u     ruser    RUSER
       %x     time     TIME
       %y     tty      TTY
       %z     vsz      VSZ

论坛徽章:
7
天蝎座
日期:2013-09-28 10:45:42双子座
日期:2013-10-16 16:27:09射手座
日期:2013-10-23 10:21:32处女座
日期:2014-09-17 16:44:332015年亚洲杯之巴林
日期:2015-04-09 17:28:01冥斗士
日期:2015-11-26 16:19:0015-16赛季CBA联赛之山东
日期:2018-03-02 23:59:31
发表于 2013-08-30 14:53 |显示全部楼层
回复 7# myworkstation

不是,是指-o后的参数。


   

论坛徽章:
17
处女座
日期:2013-08-27 09:59:352015亚冠之柏太阳神
日期:2015-07-30 10:16:402015亚冠之萨济拖拉机
日期:2015-07-29 18:58:182015年亚洲杯之巴勒斯坦
日期:2015-03-06 17:38:17摩羯座
日期:2014-12-11 21:31:34戌狗
日期:2014-07-20 20:57:32子鼠
日期:2014-05-15 16:25:21亥猪
日期:2014-02-11 17:32:05丑牛
日期:2014-01-20 15:45:51丑牛
日期:2013-10-22 11:12:56双子座
日期:2013-10-18 16:28:17白羊座
日期:2013-10-18 10:50:45
发表于 2013-08-30 15:41 |显示全部楼层
回复 8# cxytz01


    ps -p 3079 -o comm,pcpu,nice,etime=
看出来了吗?

论坛徽章:
0
发表于 2013-08-30 22:16 |显示全部楼层
本帖最后由 chzht001 于 2013-08-30 22:22 编辑
myworkstation 发表于 2013-08-28 10:53
回复 1# chzht001

 获取命令的参数有多数方式,以下是其中三种


就是不知道进程号啊, 运行脚本的时候里的的那么多命令里的一条,而且命令的运行时间不长,闪一下而已;有可能ps的时候进程还没产生呢,ps完了进程跑一下很快就结束了

要是知道pid就有办法了,strace也能跟踪
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP