对内核进行trace的方法



1.设定要trace的function
[root@localhost ~]# echo scsi:* > /sys/kernel/debug/tracing/set_event 
[root@localhost ~]# cat /sys/kernel/debug/tracing/set_event 
scsi:scsi_eh_wakeup
scsi:scsi_dispatch_cmd_timeout
scsi:scsi_dispatch_cmd_done
scsi:scsi_dispatch_cmd_error
scsi:scsi_dispatch_cmd_start


2.打开trace开关
[root@localhost ~]# echo 1 > /sys/kernel/debug/tracing/tracing_on


3.执行操作
[root@localhost ~]# date; time dd if=/dev/zero of=/dev/dm-0 bs=4k count=1 oflag=direct
Fri Oct 18 10:55:21 CST 2013
1+0 records in
1+0 records out
4096 bytes (4.1 kB) copied, 52.2694 s, 0.1 kB/s


real 0m52.271s
user 0m0.001s
sys 0m0.001s
[root@localhost ~]# 


4.关掉trace开关 
[root@localhost ~]# echo 0 > /sys/kernel/debug/tracing/tracing_on


5.检查trace的log
[root@localhost ~]# cat /sys/kernel/debug/tracing/trace
# tracer: nop
#
# entries-in-buffer/entries-written: 33/33   #P:1
#
#                              _-----=> irqs-off
#                             / _----=> need-resched
#                            | / _---=> hardirq/softirq
#                            || / _--=> preempt-depth
#                            ||| /     delay
#           TASK-PID   CPU#  ||||    TIMESTAMP  FUNCTION
#              | |       |   ||||       |         |
              dd-3613  [000] ....   860.032377: scsi_dispatch_cmd_start: host_no=0 channel=0 id=0 lun=0 data_sgl=1 prot_sgl=0 prot_op=SCSI_PROT_NORMAL cmnd=(WRITE_10 lba=0 txlen=8 protect=0 raw=2a 00 00 00 00 00 00 00 08 00)
      multipathd-3614  [000] ....   870.820735: scsi_dispatch_cmd_start: host_no=0 channel=0 id=0 lun=0 data_sgl=0 prot_sgl=0 prot_op=SCSI_PROT_NORMAL cmnd=(TEST_UNIT_READY - raw=00 00 00 00 00 00)
      multipathd-3615  [
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值