LINUX平台:
#定位core信息所对象的代码行数
addr2line -f -e proc 0x40b2d4
#查看文件失大小
du -sh ./folder
#查看占用的 socket
ls /proc/`pidof proc`/fd -l|grep socket:|wc -l
#查看连接状态以及进程的调用命令
lsof -Pn -p `pidof proc`
#查看进程的系统调用
strace -c -p `pidof proc`
strace -o php.log -s 65535 php -i
cat /proc/net/sockstat
nm -g --defined-only -C xxx.a
ar -t *.a //查看文件
lsof -c filename //查看引用的文件
ldd filepath //查看库依赖
#查看库导出
readelf -s xxx.so
#查看动态库是否带有调试符
readelf -S xxx.so | grep debug
#查看进程内存占用,单位KB
ps -e -o 'pid,comm,rsz,vsz' |grep xxx
#查看线程数
ps -eLf | grep xxx | wc -l
#查看占cpu高的前10个进程
ps aux|grep -v USER|sort +2|tail -n 10
ldd -r xxx.so或者 nm -A xxx.so //查看so有哪些符号未定义。
在makefile加上 -Xlinker --unresolved-symbols=ignore-in-shared-libs //让其报错,把未定义的符号给报错出来
yum install epel-release //安装EPEL源
统计不同的状态码数量
awk '{print $9}' access.log | sort | uniq -c | sort -rn | head -n 100
netstat -n | grep tcp | grep xxx(port) | wc -l // 查看连接数
=========================性能调优分析=======================
软件断过高分析:
#查看每个CPU中断情况:
mpstat -I SUM -P ALL 5
#查看引起软中断过高的原因:
watch -n 1 -d 'cat /proc/interrupts'
---------------------------------------------------------------------------------------------
WINDOWS平台:
使用vs自带的工具查看查看库的导入导出函数:
dumpbin /dependents xxx .exe //查看库依赖
dumpbin -exports xxx.dll (-improts) //查看库导出或导入
lib /list xxx.lib //如果输出的是dll则是动态配套库,如果是OBJ,则是静态库.
ifstat -bi eth0 //查看网卡流量
-----------------------------------------------------------------------------------------------
linux下在终端环境下可以使用free命令看到系统实际使用内存的情况,一般用free -m方式查看内存占用情况(兆为单位)。而系统实际可用内存是不是free部分呢,不是的,系统实际内存占用以及可用内存有如下几个加减法:
- used=total-free 即 total=used+free
- 实际内存占用:used-buffers-cached 即 total-free-buffers-cached
- 实际可用内存:buffers+cached+free
total used free shared buffers cached
Mem: 128 119 8 0 1 22
-/+ buffers/cache: 95 32
swap: 255 0 255
第1行Mem数据:
- total 内存总数: 128
- used 已经使用的内存数: 119
- free 空闲的内存数: 8
- shared 当前已经废弃不用,总是0
- buffers Buffer Cache内存数: 1
- cached Page Cache内存数: 22
第2行-/+ buffers/cache:
- -buffers/cache 的内存数:95 (等于第1行的 used - buffers - cached)
- +buffers/cache 的内存数: 32 (等于第1行的 free + buffers + cached)
可见-buffers/cache反映的是被程序实实在在吃掉的内存,而+buffers/cache反映的是可以挪用的内存总数。
第三行数据是交换分区SWAP的,也就是我们通常所说的虚拟内存。
gdb的使用:
#查看内存印射
i proc mem