Linux系统内存监控全面讲授[网络技术]
本文“Linux系统内存监控全面讲授[网络技术]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
在Windows系统中查看内存的利用情形很简单,想必大家都已经耳熟能详了,那么在Linux系统若何查看内存利用情形呢?下面和大家分享在Linux系统下查看内存利用情形的free号令:
1.[root@scs-2 tmp]# free
2.total used free shared buffers cached
3.Mem: 3266180 3250004 16176 0 110652 2668236
4.-/+ buffers/cache: 471116 2795064
5.Swap: 2048276 80160 1968116
下面是对这些数值的注释:
total:总计物理内存的大小.
used:已利用多大.
free:可用有多少.
Shared:多个进程同享的内存总额.
Buffers/cached:磁盘缓存的大小.
第三行(-/+ buffers/cached):
used:已利用多大.
free:可用有多少.
第四行就不多注释了.
辨别:第二行(mem)的used/free与第三行(-/+ buffers/cache) used/free的辨别. 这两个的辨别在于利用的角度来看,第一行是从OS的角度来看,因为关于OS,buffers/cached 都是属于被利用,所以他的可用内存是16176KB,已用内存是3250004KB,此中包含,内核(OS)利用+Application(X, oracle,etc)利用的+buffers+cached.
第三行所指的是从利用程序角度来看,关于利用程序来说,buffers/cached 是等于可用的,因为buffer/cached是为了提高文件读取的性能,当利用程序需在用到内存的时刻,buffer/cached会很快地被回收.
所以从利用程序的角度来说,可用内存=系统free memory+buffers+cached.
如上例:
2795064=16176+110652+2668236
接下来注释什么时刻内存会被交换,以及按什么方交换. 当可用内存少于额定值的时刻,就会开会举行交换.
若何看额定值:
1.cat /proc/meminfo
2.[root@scs-2 tmp]# cat /proc/meminfo
3.MemTotal: 3266180 kB
4.MemFree: 17456 kB
5.Buffers: 111328 kB
6.Cached: 2664024 kB
7.SwapCached: 0 kB
8.Active: 467236 kB
9.Inactive: 2644928 kB
10.HighTotal: 0 kB
11.HighFree: 0 kB
12.LowTotal: 3266180 kB
13.LowFree: 17456 kB
14.SwapTotal: 2048276 kB
15.SwapFree: 1968116 kB
16.Dirty: 8 kB
17.Writeback: 0 kB
18.Mapped: 345360 kB
19.Slab: 112344 kB
20.Committed_AS: 535292 kB
21.PageTables: 2340 kB
22.VmallocTotal: 536870911 kB
23.VmallocUsed: 272696 kB
24.VmallocChunk: 536598175 kB
25.HugePages_Total: 0
26.HugePages_Free: 0
27.Hugepagesize: 2048 kB
用free -m查看的后果:
1.[root@scs-2 tmp]# free -m
2.total used free shared buffers cached
3.Mem: 3189 3173 16 0 107 2605
4.-/+ buffers/cache: 460 2729
5.Swap: 2000 78 1921
查看/proc/kcore文件的大小(内存镜像):
1.[root@scs-2 tmp]# ll -h /proc/kcore
2.-r--- 1 root root 4.1G Jun 12 12:04 /proc/kcore
备注:
占用内存的丈量
丈量一个进程占用了多少内存,Linux系统为我们供应了一个很便利的办法,/proc目录为我们供应了全部的信息,实际上top等工具也通过这里来获得呼应的信息.
1./proc/meminfo 机械的内存利用信息
2./proc/pid/maps pid为进程号,显示当行进程所占用的虚拟地址.
3./proc/pid/statm 进程所占用的内存
4.[root@localhost ~]# cat /proc/self/statm
5.654 57 44 0 0 334 0
输出注释
CPU 以及CPU0...的每行的每个参数意思(以第一行为例)为:
参数 注释 /proc//status
Size (pages) 任务虚拟地址空间的大小 VmSize/4
Resident(pages) 利用程序正在利用的物理内存的大小 VmRSS/4
Shared(pages) 同享页数 0
Trs(pages) 程序所拥有的可履行虚拟内存的大小 VmExe/4
Lrs(pages) 被映像到任务的虚拟内存空间的库的大小 VmLib/4
Drs(pages) 程序数据段和用户态的栈的大小 (VmData+ VmStk )4
dt(pages) 04
查看机械可用内存
1./proc/28248/>free
2.total used free shared buffers cached
3.Mem: 1023788 926400 97388 0 134668 503688
4.-/+ buffers/cache: 288044 735744
5.Swap: 1959920 89608 1870312
我们通过free号令查看机械闲暇内存时,会发现free的值很小.这主如果因为,在Linux系统中有这么一种思惟,内存不用白不用,因此它尽大概的cache和buffer一些数据,以便利下次利用.但实际上这些内存也是可以立即拿来利用的.
所以 闲暇内存=free+buffers+cached=total-used
以上是“Linux系统内存监控全面讲授[网络技术]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |