solaris查看内存使用情况命令

本文介绍了SOLARIS系统中几种常用的内存监控方法,包括使用ps、prtconf、mdb、prstat、vmstat、top及sar命令来查看内存使用情况、进程状态和系统负载等关键信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1>ps -efo pmem,uid,pid,ppid,pcpu,comm | sort -r
用PS命令的-o选项来实现,这些选项有:user ruser group rgroup uid ruid gid rgid pid ppid pgid sid taskid ctid pri opri pcpu pmem vsz rss osz nice class time etime stime zone zoneid f s c lwp nlwp psr tty addr wchan fname comm args projid project pset
具体的意思可以man ps来查看。
 
查看solaris内存使用情况,按占用内存大小排序 
ps -efo pmem,uid,pid,ppid,pcpu,comm | sort -r
 
pmem   The ratio of the process's resident  set size  to  the  physical  memory  on 
       the machine, expressed as a percentage.
 
如果你不知道这个命令都带有什么选项, ps help即可。
 
2> # prtconf -vp | grep Mem
prtconf 命令在/usr/sbin下,这个命令可以得到总内存。其实也不用这么麻烦,top命令看到的信息更多。
 
3> echo ::memstat | mdb -k
例如:
# echo ::memstat | mdb -k
Page Summary                Pages                MB  %Tot
------------     ----------------  ----------------  ----
Kernel                      75297               588    7%
Anon                       888409              6940   86%
Exec and libs               28196               220    3%
Page cache                  15958               124    2%
Free (cachelist)            17993               140    2%
Free (freelist)              3162                24    0%
Total                     1029015              8039
Physical                  1026087              8016
 
具体解释:
Kernel: Kernel pages
Anon: anonymous pages (such as stack, heap, shared mem etc)
Exec and libs: executables and libraries
Page cache:  file cache
Free (cachelist) + Free (freelist) = freemem(vmstat 中的free值)
这个命令运行起来时间比较长。
 
4>prstat -a
 *PID      :进程的进程 ID。
 *USERNAME :真实用户(登录)名称或真实用户 ID。
 *SIZE     :进程的总虚拟内存大小,以 K、M 或 G 为单位。
 *RSS      :进程的驻留集大小 (RSS),以 K、M 或 G 为单位。(RSS是进程驻留内存的大小,SIZE是进
             程总共的大小。一般SIZE要大于RSS,至于SIZE大于RSS的部分就放到了SWAP区里了)
 *STATE    :进程的状态 (cpuN/sleep/wait/run/zombie/stop)。
 *PRI      :进程的优先级。数字更大表示优先级更高。
 *NICE     :优先级计算中使用的 nice 值。只有特定调度类中的进程才有 nice 值。
 *TIME     :进程的累计执行时间。
 *CPU      :进程使用的当前 CPU 时间的百分比。如果在非全局域中执行并且池设备是活动的,百分比将
             zone绑定的池所使用的处理器集合中处理器的百分比。
 *PROCESS  :进程的名称(执行文件的名称)。
 *NLWP     :进程中 lwps 的数量
 
中间还有个参数:系统平均负载(Load average)在Linux系统中,uptime、w、top等命令都会有系统平均负载load average的输出.
命令输出的最后内容表示在过去的1、5、15分钟内运行队列中的平均进程数量。 只要每个CPU的当前活动进程数不大于3那么系统的性能就是良好的,如果每个CPU的任务数大于5,那么就表示这台机器的性能有严重问题。load average/cpu_num< 3 就是性能不错的。
顺便提一下,多个CPU状态查看命令:mpstat
 
5>vmstat 3 4
看vmstat的输出时,从第2行开始看,如果sr列数值比较大,就表明内存紧张。

 
6>top
 
7>sar -r 5 5 
sar -r标示的freemem显示的是空闲的页面数,而不是用k来衡量的,它表示的数值与vmstat差不多。
它们显示的free memory都还包括高速文件缓存占用的的内存,并不是真正没有使用的内存。

比如:vmstat显示的内存有152528k,sar -r显示的是18933个pages,一个page大约8k,用18933乘以8,还是差不多150M.但实际上呢,真正意义上空闲的内存只有6个M(用专门的memtool测量的),而不是152M。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值