文档章节

AIX详细查看用户/进程使用内存

Goopand
 Goopand
发布于 2015/10/21 10:14
字数 1319
阅读 33
收藏 1

问题描述:

通过topas发现%comp内存已使用98%  

 

问题分析:  

1,从大到小排列10个内存使用率进程

ps aux |  head -1 ;  ps aux |  sort -rn +3 |  head -10

如详细查看进程: ps -ealf |  head -1 ;  ps -ealf |  sort -rn +9 |  head    -10

(另参照:

ps gv | head -n 1; ps gv | egrep -v "RSS" | sort +6b -7 -n -r

以进程占用内存量从大到小排列,SIZE单位为k。

 

 

# ps aux | head -1 ; ps aux | sort -rn +3 | head -10

USER         PID %CPU %MEM   SZ  RSS    TTY STAT    STIME  TIME COMMAND

root     6553834  0.1  3.0 115064 115080      - A      Feb 20 86:08 /var/opt/tivoli

root     5701730  0.0  1.0 17480 21956      - A      Mar 05  1:17 /opt/BESClient/

pconsole 4456680  0.0  1.0 42456 42464      - A      Feb 20  3:11 /usr/java5/bin/

root     6750376  0.0  0.0  796  824  pts/0 A    11:29:26  0:00 ps aux 

root     6488234  0.0  0.0  260  268      - A      Mar 13  0:02 auditbin 

root     6357208  0.0  0.0  236  248  pts/0 A    11:29:26  0:00 sort -rn +3 

root     5963962  0.0  0.0 1768 1804      - A      Feb 20  0:00 /usr/sbin/rsct/

root     5832798  0.0  0.0  836  856      - A    11:29:12  0:00 telnetd -a 

root     5570748  0.0  0.0 2128 2096      - A      Feb 20  0:00 /usr/sbin/rsct/

root     5308652  0.0  0.0 7328 7436      - A      Feb 20  1:01 /usr/sbin/rsct/

 

2,根据某个命令或进程名,查看内存使用率

# ps aux | head -1 ; ps aux | grep topas

如详细查看:

USER         PID %CPU %MEM   SZ  RSS    TTY STAT    STIME  TIME COMMAND

root     2359426  0.0  0.0 1440 1272      - A      Feb 20  1:08 /usr/bin/topasr

root     6160578  0.0  0.0  252  264  pts/0 A    11:36:45  0:00 grep topas 

但有的时候ps aux并不能非常详细地表现出进程的完整使用率

 

3,通过root用户svmon用户可以分析出内存使用量

# svmon -G

               size       inuse        free         pin     virtual   mmode

memory      1048576     1037487       11089      229668      378796     Ded

pg space    2097152        2360

               work        pers        clnt       other

pin          196952           0           0       32716

in use       378796           0      658691

PageSize   PoolSize       inuse        pgsp         pin     virtual

s    4 KB         -      793327        2360       49188      134636

m   64 KB         -       15260           0       11280       15260

inuse:是物理内存使用量,这里是以4K为单位,所以 1037487*4096=4249546752(424M)

virtual:是虚拟内存使用量,这里是以4K为单位,所以 378796*4096=1551548416(155M)

 

4,显示使用物理内存最多的3个进程:

# svmon -uP -t 3|grep -p Pid|grep '^.*[0-9]'

 6553834 java             51279     8917        0    50938      N     Y     N

 4456680 java             34626     8874        0    34608      N     Y     N

 5701730 BESClient        29564     8882        0    25689      Y     Y     N

输出的格式顺序为 Pid Command Inuse Pin Pgsp Virtual 64-bit Mthrd 

可以计算出X程序所使用的实存为51279×4096=210038784,约为210MB 

 

5,显示交换区使用物理内存最多的3个进程

# svmon -gP -t 3|grep -p Pid|grep '^.*[0-9]'

 1966206 shlap64          26782     8880        0    26771      Y     N     N

       0 swapper           9872     8912        0     9872      Y     N     N

       1 init             22094     8836        0    22076      N     N     N

第一个程序X所使用的交换区大小约为 26782×4096 =10510336 字节,大约为10MB空间 

 

6,每隔三秒显示使用最多的段

# svmon -S -t 3 -i 3 

Vsid Esid Type Description Inuse Pin Pgsp Virtual 

4f08 -    clnt 37505 0 - - 

11e1 -    clnt 33623 0 - - 

8811 -    work kernel pinned heap 12637 6547 8091 19397 

可见,Vsid为4f08的段使用最多 

 

7,svmon -pP 22674 

看PID为22674的进程所使用的为那些文件 

Pid Command nuse Pin Pgsp Virtual 64-bit Mthrd 

22674 java 29333 1611 2756 32404 N Y 

 

Vsid Esid Type Description Inuse Pin Pgsp Virtual 

0 0 work kernel seg 2979 1593 1659 4561 

a056 - work 43 16  3   46 

1e03 2 work process private 77 2   17  93 

1080 - pers /dev/hd2:69742 1 0   -   - 

f8bd f work shared library data 84 0   11  99 

60ee 8 work shmat/mmap 0 0   0   0 

70ec - pers /dev/hd2:69836 1 0   -   - 

 

8,通过ncheck命令,检查Vsid都使用了哪些文件。

ncheck a056

 

 

附件1:查看物理内存总量

# cat mem1.sh

#!/usr/bin/ksh

#mem totle

totalmem=$(vmstat -v|head -n 1|awk '{print $1/256}')

echo "mem totle:"

echo $totalmem MB

echo

 

附件2:查看每个用户占用物理内存的数量

# cat mem2.sh

usermem=$(for username in `cat /etc/passwd|awk -F: '{print $1}'`

do

svmon -U $username|grep $username" "

done)

usermem=`echo "$usermem"|grep -v "0        0        0        0"|awk '{print $1,$2/256,"MB"}'`

echo "singe user pmem"

echo "$usermem"

usermem=$(echo "$usermem"|awk 'BEGIN{sum1=0;}{sum1=sum1+$2;}END{print sum1;}')

usermem=$(echo $usermem|awk -F\. '{print $1}')

echo "singe user pmem :" $usermem MB

echo

 

AIX5.3下查看系统、用户、文件系统占用内存数量

#!/usr/bin/ksh

#查看总的内存数量:

totalmem=$(vmstat -v|head -n 1|awk '{print $1/256}')

echo "总内存(物理内存):"

echo $totalmem MB

echo

 

#查看各用户使用的内存:

usermem=$(for username in `cat /etc/passwd|awk -F: '{print $1}'`

do

svmon -U $username|grep $username" "

done)

usermem=`echo "$usermem"|grep -v "0        0        0        0"|awk '{print $1,$2/256,"MB"}'`

echo "各用户内存(物理内存):"

echo "$usermem"

usermem=$(echo "$usermem"|awk 'BEGIN{sum1=0;}{sum1=sum1+$2;}END{print sum1;}')

usermem=$(echo $usermem|awk -F\. '{print $1}')

echo "用户内存(物理内存)合计:" $usermem MB

echo

 

#查看文件系统缓存:

clientmem1=`svmon -G|grep "^pin"|awk '{print $4}'`

clientmem2=`svmon -G|grep "^in use"|awk '{print $5}'`

clientmem=`expr $clientmem1 + $clientmem2`

clientmem=`expr $clientmem / 256`

echo "文件系统缓存(物理内存):"

echo $clientmem MB

echo

 

#查看系统使用内存:

sysmem=$(svmon -S -s -u|cut -b 54-|grep -v "0     0    0     0"|grep [0-9]|awk '{print $1,$2}')

supremeseg=`echo "$sysmem"|grep S|awk 'BEGIN{sum1=0;}{sum1=sum1+$2;}END{sum1=sum1*16*1024*1024;print sum1;}'`

largeseg=`echo "$sysmem"|grep L|awk 'BEGIN{sum1=0;}{sum1=sum1+$2;}END{sum1=sum1*16*1024;print sum1;}'`

mediumseg=`echo "$sysmem"|grep m|awk 'BEGIN{sum1=0;}{sum1=sum1+$2;}END{sum1=sum1*64;print sum1;}'`

smallseg=`echo "$sysmem"|grep s|awk 'BEGIN{sum1=0;}{sum1=sum1+$2;}END{sum1=sum1*4;print sum1;}'`

sysmem=$(expr $supremeseg + $largeseg + $mediumseg + $smallseg)

sysmem=$(expr $sysmem / 1024)

echo "系统内存(物理内存):"

echo $sysmem MB

echo

 

#查看空闲内存:

freemem=$(vmstat -v|grep free|awk '{print $1/256}')

echo "空闲内存(物理内存):"

freemem=$(echo $freemem|awk -F\. '{print $1}')

echo $freemem MB

echo

 

本文转载自:http://blog.csdn.net/scofy0/article/details/46605711

共有 人打赏支持
Goopand
粉丝 8
博文 392
码字总数 196343
作品 0
朝阳

暂无文章

使用JDK自带的jmap和jhat监控处于运行状态的Java进程

对于处于运行状态中的Java进程,JDK自带了很多工具,允许Java开发人员监控运行进程中的各种状态,比如该进程内部创建了多少个对象实例,消耗了多少内存,等等。 本文基于JDK1.8而写成。 我下...

JerryWang_SAP
17分钟前
1
0
下单接口调优实战,性能提高10倍

概述 最近公司的下单接口有些慢,老板担心无法支撑双11,想让我优化一把,但是前提是不允许大改,因为下单接口太复杂了,如果改动太大,怕有风险。另外开发成本和测试成本也非常大。对于这种...

Sam哥哥聊技术
50分钟前
4
1
rabbitMQ的安装和配置

在Windows下进行rabbitMQ的安装 第一步:软件下载 在安装rabbitMQ之前,需要先安装Erlang。 Erlang官网:http://www.erlang.org/downloads rabbitMQ官网:http://www.rabbitmq.com/download....

狼王黄师傅
今天
3
0
Vue-Element-Upload

记录一下文件上传封装Js 代码示例 封装:uploadFile.vue <template> <el-upload v-model="attachment" ref="upload" class="upload-demo" :action="uploadUrl" ......

华山猛男
今天
4
0
AWVS破解及使用手册

1.安装 因为是windows软件,比较简单,此部分略: 破解插件下载: 链接: https://pan.baidu.com/s/1x9LK9F3KvqDgTvXDjoSZnQ 提取码: 7k4u 2.创建扫描目标 2-1.Targets->Add Target 2-2.对话框...

硅谷课堂
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部