作者:morimodomasaaki | 来源:互联网 | 2023-07-20 17:11
最近需要对一个自己开发的socketserver的性能进行分析,刚开始还想了好长时间怎么来分析。后来才意识到其实使用strace就足够了。观察到的现象是server单进程CPU使用率97,但磁盘i
最近需要对一个自己开发的socket server的性能进行分析,刚开始还想了好长时间怎么来分析。后来才意识到其实使用strace就足够了。
观察到的现象是server单进程CPU使用率97,但磁盘i/o只有400MB/s,但这块磁盘可以达到>1GB/s的速度,于是在server开始跑之后直接用
strace -r -p pid -o outfile
cat outfile |awk -F'(' '{print $1}'|awk '{print $1,$2}' >outfile.count
之后拉到excel表里用透视图一看,就可以看到再做和client交互就使用了40%的时间,所以i/o 上不去就很正常了。
Update:
貌似 strace -c -p pid -o outfile就可以直接看统计信息了,不需要再自己折腾一遍了。
Update 2:
strace -r -T -p pid -o outfile可以看到每个时间执行的相对时间,和时间本省的执行时间,这个在无法看到源程序的情况下去分析一个程序的运行时间还是非常有用的。