简介
内存分析很多命令重复敲,很麻烦,虽然可以写到bashrc里,但是环境总是切换,所以做个记录
获取进程所有代码段的内存映射区间
命令:
# 1. cat 获取内存信息
# 2. grep 筛选内存映射信息行
cat /proc/`pidof {唯一进程名}`/smaps |\
grep "[0-9a-z]\+\-[0-9a-z]\+ ..x."
效果:
00400000-00403000 r-xp 00000000 08:01 932911 /home/suchp/suchp_familly/github/project/myapp/build/linux/x64/release/bundle/myapp
7f1ba0300000-7f1ba0d00000 rwxp 00000000 00:00 0
7f1ba16b0000-7f1ba16b5000 r-xp 00000000 08:01 1573497 /usr/lib/x86_64-linux-gnu/gdk-pixbuf-2.0/2.10.0/loaders/libpixbufloader-png.so
7f1ba2587000-7f1ba2593000 r-xp 00000000 08:01 1447203 /usr/lib/x86_64-linux-gnu/gio/modules/libdconfsettings.so
7f1ba2794000-7f1ba27a5000 r-xp 00000000 08:01 1321733 /usr/lib/x86_64-linux-gnu/libwayland-server.so.0.1.0
7f1ba29a7000-7f1ba29ae000 r-xp 00000000 08:01 1321798 /usr/lib/x86_64-linux-gnu/libxcb-xfixes.so.0.0.0
7f1ba2baf000-7f1ba2bbc000 r-xp 00000000 08:01 1321015 /usr/lib/x86_64-
获取某个地址的所在动态库
命令:
# 1. cat 获取内存信息
# 2. grep 筛选内存映射信息行
# 3. -F' ' 按照空格分片
# 4. center是你要计算的地址
# 5. $1是分片后的地址范围,例如:7f1bd6985000-7f1bd6999000
# 6. 筛选符合的行后,打印库已经地址在库中的偏移地址
cat /proc/`pidof {唯一进程名}`/smaps |\
grep "[0-9a-z]\+\-[0-9a-z]\+ ..x." |\
gawk -F' ' '{ \
center=strtonum(0x7f1bd90dd010); \
split($1,r,"-"); \
left=strtonum("0x"r[1]); \
right=strtonum("0x"r[2]); \
if(left<=center && right>=center) \
printf "0x%x,%s\n",center-left,$6 \
}'
效果:
suchp@suchp-VirtualBox:~/exam/test_new$ cat /proc/`pidof {唯一进程名}`/smaps |\
grep "[0-9a-z]\+\-[0-9a-z]\+ ..x." |\
gawk -F' ' '{ \
center=strtonum(0x7f1bd90dd010); \
split($1,r,"-"); \
left=strtonum("0x"r[1]); \
right=strtonum("0x"r[2]); \
if(left<=center && right>=center) \
printf "0x%x, %s\n",center-left,$6 \
}'
0x10, /usr/lib/x86_64-linux-gnu/libgio-2.0.so.0.5600.4
suchp@suchp-VirtualBox:~/exam/test_new$
统计进程大于1M的内存占用的总和
命令
# 第一次过滤出 Rss实际物理内存占用
# 第二次过滤出大于1M的物理内存占用
# 第三次for循环计算总和
cat /proc/`pidof {唯一进程名}`/smaps |\
grep "Rss:" |\
awk -F' ' '{if($2 > 1024) print $2}' |\
awk '{for(i=1;i<=NF;i++) sum+=$i; print sum}'