免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2563 | 回复: 0
打印 上一主题 下一主题

查看进程内存真实占用情况的脚本 [复制链接]

论坛徽章:
3
数据库技术版块每日发帖之星
日期:2015-06-18 22:20:00数据库技术版块每日发帖之星
日期:2015-06-21 22:20:00数据库技术版块每日发帖之星
日期:2015-08-27 06:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-01-31 19:45 |只看该作者 |倒序浏览
在Linux下使用ps v 查看oracle进程看到的内存并不正确,如果SGA没有使用大页管理,则原因是ps会把oracle进程使用到的共享内存也加到进程使用的内存中,实际这块共享内存是所有进程共享的,如果使用了大页管理,虽然没有把共享内存算进去,但会把共享的代码页的部份加进去,实际上共享的代码页,不管oracle启动多少个进程,这个代码页在内存中只有1份,为此写了一个脚本程序pm,用于显示进程的真实的内存情况。

[email=root@bopspri:/proc/5890>pm]root@/usr/bin>pm.sh[/email]
-p 5890         
   pid     RSS(KB)   PRI_DIRTY  PRIV_CLEAN SHR_DIRTY  SHR_CLEAN    SWAP     PAGETABLE     CMDLINE
--------- ---------- ---------- ---------- ---------- ---------- ---------- ---------- ----------------
     5890      68356         12      40424      27920          0          0        412 ora_dbw0_testdb           
其中RSS:表示了进程使用到代码段共享部分的内存和私有部分的内存之和;
   PRI_DIRTY:private_dirty,私有的脏内存页的大小;   
   PRIV_CLEAN:private_clean,私有的干净内存页的大小;
   SHR_DIRTY:shared_dirty,共享的脏内存页的大小,这里指代码页等共享的部分,而没有包括共享内存的部分;
   SRH_CLEAN:shared_clean,共享的干净内存页的大小,这里指代码页等共享的部分,而没有包括共享内存的部分;
   SWAP:指进程使用的swap空间的大小。
   PAGETABLE:指进程的虚拟地址和物理地址映射时pagetable的大小。
所以对于oracle进程来说,一个进程占用内存的大小为:PRI_DIRTY+PRI_CLEAN+PAGETABLE,而SHR_CLEAN+SHR_DIRTY是对所有oracle进程共享的。
注意,如果没有大页管理(HugeTLB),oracle进程的pagetable可能消耗很大的内存。
排除共享内存的内存办法是cat /proc/smaps中:
60000000-103200000 rwxs 00000000 00:0d 3309576                           /SYSVXXXX (deleted)
Size:           2672640 kB
Rss:            xxxxxxx kB
Shared_Clean:      xxxx kB
Shared_Dirty:      xxxx kB
Private_Clean:     xxxx kB
Private_Dirty:     xxxx kB
Swap:        0 kB

文件名类似 “/SYSV”就是共享内存的部分,在脚本有把这部分排除出去,就可以了。

60000000-103200000 rwxs 00000000 00:0d 3309576                           /12 (deleted)
Size:           2672640 kB
Rss:                  0 kB
Shared_Clean:         0 kB
Shared_Dirty:         0 kB
Private_Clean:        0 kB
Private_Dirty:        0 kB






文件:
pm.zip
大小:
1KB
下载:
下载
代码如下:



#!/bin/bash
#****************************************************************#
# ScriptName: pm
# Author: osdba
# Create Date: 2010-01-31
# Modify Author:
# Modify Date: 2010-01-31
# Function: show processes memory used
#***************************************************************#
function getpidmem()
{
cat /proc/$1/smaps 2>/dev/null |awk  \
'BEGIN{
    total_size=0;
    total_rss=0;
    total_shared_clean=0;
    total_shared_dirty=0;
    total_private_clean=0;
    total_private_dirty=0;
    total_swap=0;
   
    mem_size=0;
    mem_rss=0;
    mem_shared_clean=0;
    mem_shared_dirty=0;
    mem_private_clean=0;
    mem_private_dirty=0;
    mem_swap=0;
}
{
    if($1 ~ /^Size:/)
    {
        mem_size=$2;
    }
    else if($1 ~ /^Rss:/)
    {
        mem_rss=$2;
    }
    else if($1 ~ /^Shared_Clean:/)
    {
        mem_shared_clean=$2;
    }
    else if($1 ~ /^Shared_Dirty:/)
    {
        mem_shared_dirty=$2;
    }
    else if($1 ~ /^Private_Clean:/)
    {
        mem_private_clean=$2;
    }
    else if($1 ~ /^Private_Dirty:/)
    {
        mem_private_dirty=$2;
    }
    else if($1 ~ /^Swap:/)
    {
        mem_swap=$2;
    }
    else
    {
        if(ipcmem_start==1)
        {
            ipc_size=mem_size;
            ipc_rss=mem_rss;
            ipc_shared_clean=mem_shared_clean;
            ipc_shared_dirty=mem_shared_dirty;
            ipc_private_clean=mem_private_clean;
            ipc_private_dirty=mem_private_dirty;
            ipc_swap=mem_swap;
        }
        else
        {
            total_size=total_size+mem_size;
            total_rss=total_rss+mem_rss;
            total_shared_clean=total_shared_clean+mem_shared_clean;
            total_shared_dirty=total_shared_dirty+mem_shared_dirty;
            total_private_clean=total_private_clean+mem_private_clean;
            total_private_dirty=total_private_dirty+mem_private_dirty;
            total_swap=total_swap+mem_swap;
        };
        if($6 ~ /^\/SYSV/)
        {
            ipcmem_start=1;            
        }
        else
        {
            ipcmem_start=0;        
        };
    };
}
END{
    printf("%15d %15d %15d %15d %15d %15d\n",total_rss,total_private_clean,total_private_dirty,total_shared_clean,total_shared_dirty,total_swap);
}
'
}
function show_all_process_mem()
{
    TMPFILE=`/bin/mktemp -q`
    echo "   pid     RSS(KB)   PRIV_DIRTY PRIV_CLEAN SHR_DIRTY  SHR_CLEAN    SWAP     PAGETABLE      CMDLINE"
    echo "--------- ---------- ---------- ---------- ---------- ---------- ---------- ---------- ----------------"
    ls -ld /proc/[0-9]* |awk '{printf("%s\n",$NF)}' > $TMPFILE
    while read LINE
    do
        PID=`basename $LINE`
        cmdline=`ps -o command -p $PID |tail -1  |cut -b 1-26`
        pagetablesize=`cat /proc/$PID/status |grep "VmPTE:"|awk '{print $2}'`
        if [ "$pagetablesize" = "" ] ; then
            pagetablesize=0
        fi
        
        meminfoline=`getpidmem $PID`
        rss=`echo $meminfoline |awk '{print $1}'`
        private_clean=`echo $meminfoline |awk '{print $2}'`
        private_dirty=`echo $meminfoline |awk '{print $3}'`
        shared_dirty=`echo $meminfoline |awk '{print $4}'`
        shared_clean=`echo $meminfoline |awk '{print $5}'`
        swap=`echo $meminfoline |awk '{print $6}'`
        total_rss=$((total_rss+rss))
        total_private_clean=$((total_private_clean+private_clean))
        total_private_dirty=$((total_private_dirty+private_dirty))
        total_shared_dirty=$((total_shared_dirty+shared_dirty))
        total_shared_clean=$((total_rss+shared_clean))
        total_swap=$((total_swap+swap))
        total_pagetablesize=$((total_pagetablesize+pagetablesize))
        if [ "$1" = "-a" ] ;then
            echo $PID $meminfoline "$pagetablesize" "$cmdline"|awk \
            '{
              printf("%9d %10d %10d %10d %10d %10d %10d %10d %-26s\n",$1,$2,$3,$4,$5,$6,$7,$8,$9);
            }'
        fi
    done
    echo $total_rss $total_private_clean $total_private_dirty $total_shared_dirty $total_shared_clean $total_swap $total_pagetablesize |awk \
    '{
        printf("   ALL    %10d %10d %10d %10d %10d %10d %10d\n",$1,$2,$3,$4,$5,$6,$7);
    }'
}
function print_usage()
{
    echo "usage:"
    echo "  pm.sh -a : display all process memory info"
    echo "  pm.sh -s : display total memory info"
    echo "  pm.sh -p  : display pid memory info"
}
total_rss=0
total_private_clean=0
total_private_dirty=0
total_shared_dirty=0
total_shared_clean=0
total_swap=0
total_pagetablesize=0
if [ $# -lt 1 ];then
   print_usage;
   exit 1
fi
if [ "$1" = "-a" ];then
    show_all_process_mem $1;
    exit 0
fi
if [ "$1" = "-s" ];then
    show_all_process_mem $1;
    exit 0
fi
if [ "$1" = "-p" ];then
    if [ $# -ne 2 ];then
        print_usage;
        exit 1
    fi
   
    meminfoline=`getpidmem $2`
    cmdline=`ps -o command -p $2 |tail -1  |cut -b 1-26`
    pagetablesize=`cat /proc/$2/status |grep "VmPTE:"|awk '{print $2}'`
    if [ "$pagetablesize" = "" ]; then
        pagetablesize=0
    fi
        
    echo "   pid     RSS(KB)   PRIV_DIRTY PRIV_CLEAN SHR_DIRTY  SHR_CLEAN    SWAP     PAGETABLE     CMDLINE"
    echo "--------- ---------- ---------- ---------- ---------- ---------- ---------- ---------- ----------------"
    echo $2 $meminfoline "$pagetablesize" "$cmdline"|awk \
    '{
        printf("%9d %10d %10d %10d %10d %10d %10d %10d %-26s\n",$1,$2,$3,$4,$5,$6,$7,$8,$9);
    }'
    exit 0
fi




本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u2/84422/showart_2165862.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP