有时候我们需要查看一个任务的调度情况可以通过 cat /proc/$pid/status | grep switch来判断任务有没有切换。但是任务出问题,得不到调度的时机是不确定的。
如果我们希望在任务没有及时得到调度的时候及时的做出报告,以便我们能够及时处理,下面这个脚本值得一试:
#!/bin/sh
if [ $argc != 1 ]; then
echo "USAGE:$0 pid"
exit 0
fi
pid=`ps -T | grep $1 | grep -v grep | awk '{print $1}'`
oldsw=`cat /proc/$pid/status | grep ^voluntary_ctxt_switch | awk '{print $2}'`
chrt -r -p 99 $$
while [ 1 ]
do
sleep 1
newsw=`cat /proc/$pid/status | grep ^voluntary_ctxt_switch | awk '{print $2}'`
if [ $newsw = $oldsw ]; then
echo " ---- task[$pid] may hungray:newsw=$newsw, oldsw=$oldsw "
date
cat /proc/$pid/stack
else
echo $newsw
fi
oldsw=$newsw
done
[Click and drag to move]