linux 内存使用分析
查看当前内存使用情况,最常用的指令就是
[root@t ~]# free -m
total used free shared buffers cached
Mem: 22812
-/+ buffers/cache: 23386
Swap:
-/+ buffers/cached:表示物理内存的缓存统计
Swap:表示硬盘上交换分区的使用情况
我们使用total1、used1、free1、used2、free2 等名称来代表上面统计数据的各值,1、2 分别代表第一行和第二行的数据。
used1: 表示总计分配给缓存(包含buffers 与cache )使用的数量,但其中可能部分缓存并未实际使用。
free1: 未被分配的内存。
shared1: 共享内存,一般系统不会用到,这里也不讨论。
buffers1: 系统分配但未被使用的buffers 数量。
cached1: 系统分配但未被使用的cache 数量。buffer 与cache 的区别见后面。
free2: 未被使用的buffers 与cache 和未被分配的内存之和,这就是系统当前实际可用内存
[root@~]# cat /proc/meminfo
MemTotal: 131789100 kB
MemFree: 23367084 kB
MemAvailable: 23872172 kB
Buffers: 228 kB
Cached: 997224 kB
SwapCached: 0 kB
Active: 96364752 kB
Inactive: 10617236 kB
Active(anon): 95958228 kB
Inactive(anon): 10431640 kB
Active(file): 406524 kB
Inactive(file): 185596 kB
Unevictable: 0 kB
Mlocked: 0 kB
SwapTotal: 0 kB
SwapFree: 0 kB
Dirty: 4 kB
Writeback: 0 kB
AnonPages: 105983064 kB
Mapped: 62720 kB
Shmem: 405332 kB
Slab: 272340 kB
SReclaimable: 163808 kB
SUnreclaim: 108532 kB
KernelStack: 13344 kB
PageTables: 245164 kB
NFS_Unstable: 0 kB
Bounce: 0 kB
WritebackTmp: 0 kB
CommitLimit: 65894548 kB
Committed_AS: 119839644 kB
VmallocTotal: 34359738367 kB
VmallocUsed: 362048 kB
VmallocChunk: 34359360512 kB
HardwareCorrupted: 0 kB
AnonHugePages: 66662400 kB
HugePages_Total: 0
HugePages_Free: 0
HugePages_Rsvd: 0
HugePages_Surp: 0
Hugepagesize: 2048 kB
DirectMap4k: 353264 kB
DirectMap2M: 25800704 kB
DirectMap1G: 110100480 kB
说明:
MemTotal: 131789100 kB 可用的总内存--总物理内存减去kernel 代码/数据段占用再减去保留的内存区,系统从加电开始到引导完成,firmware/BIOS要保留一些内存,kernel本身要占用一些内存,最后剩下可供kernel支配的内存就是MemTotal。这个值在系统运行期间一般是固定不变的。
MemFree: 23367084 kB 完全未用到的物理内存 LowFree+HighFree,[MemTotal-MemFree]就是已被用掉的内存。这是从OS角度搜集的数据。
MemAvailable: 23872172 kB 字面意思为可用内存,这是一个从应用角度搜集的数据,是内核使用特定的算法估算出来的,要注意这是一个估计值,并不精确。从应用程序的角度来说,可用内存=系统free( memory+buffers+cached.)
Buffers: 228 kB 缓冲区,一个用于存储速度不同步的设备或优先级不同的设备之间传输数据的区域。通过缓冲区,可以使进程之间的相互等待变少,从而使从速度慢的设备读入数据时,速度快的设备的操作进程不发生间断。
Cached: 997224 kB 高速缓存,是位于CPU与主内存间的一种容量较小但速度很高的存储器。由于CPU的速度远高于主内存,CPU直接从内存中存取数据要等待一定时间周 期,Cache中保存着CPU刚用过或循环使用的一部分数据,当CPU再次使用该部分数据时可从Cache中直接调用,这样就减少了CPU的等待时间,提 高了系统的效率。
缓存(cached)是把读取过的数据保存起来,重新读取时若命中(找到需要的数据)就不要去读硬盘了,若没有命中就读硬盘。其中的数据会根据读取频率进行组织,把最频繁读取的内容放在最容易找到的位置,把不再读的内容不断往后排,直至从中删除。
缓冲(buffers)是根据磁盘的读写设计的,把分散的写操作集中进行,减少磁盘碎片和硬盘的反复寻道,从而提高系统性能。linux有一个守护进程定 期清空缓冲内容(即写如磁盘),也可以通过sync命令手动清空缓冲。
SwapCached: 0 kB 内存足够的情况下,这个值一般为0
那些匿名内存页,比如用户进程通过malloc()申请的内存页是没有关联任何文件的(有别于backing storage基于磁盘文件的内存页),如果发生swapping换页,这类内存页会被写入交换区。从一个匿名内存页被确定要被换页开始,它就被计入了swap cache,但是不一定会被立刻写入物理交换区,因为Linux的原则是除非绝对必要,尽量避免I/O。所以swap cache中包含的是被确定要swapping换页、但是尚未写入物理交换区的匿名内存页。
Active: 95675704 kB (pages[LRU_ACTIVE_ANON] + pages[LRU_ACTIVE_FILE]),缓冲或页面缓存内存的总量,活跃的使用 这是最近的内存回收和通常不用于其他目的。
Inactive: 5615140 kB pages[LRU_INACTIVE_ANON] + pages[LRU_INACTIVE_FILE],缓冲或页面缓存内存的总量,这是免费的和可用的。这是最近没有使用内存,可以回收用于其他目的。
Active(anon): 95590152 kB 分别表示anonymous pages和mapped pages。用户进程的内存页分为两种:与文件关联的内存(比如程序文件、数据文件所对应的内存页)和与文件无关的内存(比如进程的堆栈,用malloc申请的内存),前者称为file pages或mapped pages,后者称为anonymous pages,这部分具体可以参考LRU 内存管理算法,
HighMem跟LowMem是32bitX86 上面的一种划分,860MB以上内存成为HighMem,ARM架构上面没有这样的划分方式;
Inactive(anon): 5579872 kB
Active(file): 85552 kB
Inactive(file): 35268 kB
Unevictable: 0 kB
Mlocked: 0 kB
SwapTotal: 31743996 kB 可用的swap空间的总的大小
SwapFree: 24693072 kB 剩余swap空间的大小,内存换出到swap的过程,kswapd()-->balance_pgdat()-->shrink_zone()-->shrink_inactive_list()-->shrink_page_list()(核心函数)-_swap()-->get_swap_page()
Dirty: 12 kB 需要写入磁盘的内存区大小
Writeback: 0 kB 正在被写回磁盘的大小
AnonPages: 100707440 kB 未映射页的内存大小
Mapped: 61560 kB 设备和文件等映射的大小。
Shmem: 154012 kB
Slab: 272120 kB 内核数据结构slab的大小,可以减少申请和释放内存带来的消耗。
SReclaimable: 169236 kB 可收回Slab的大小
SUnreclaim: 102884 kB 不可收回Slab的大小(SUnreclaim+SReclaimable=Slab)
KernelStack: 13352 kB
PageTables: 245108 kB 管理内存分页页面的索引表的大小。
NFS_Unstable: 0 kB
Bounce: 0 kB
WritebackTmp: 0 kB
CommitLimit: 97638544 kB
Committed_AS: 119813492 kB 内存的总量估计完成工作量。 这个值代表的是最坏的情况下的价值,还包括交换内存。
VmallocTotal: 34359738367 kB 内存的总量分配总量的虚拟地址空间。
VmallocUsed: 370836 kB 使用虚拟地址空间
VmallocChunk: 34359359536 kB 最大的连续内存块,可用的虚拟地址空间。
HardwareCorrupted: 0 kB
AnonHugePages: 66578432 kB
HugePages_Total: 0
HugePages_Free: 0
HugePages_Rsvd: 0
HugePages_Surp: 0
Hugepagesize: 2048 kB
DirectMap4k: 353264 kB
DirectMap2M: 25800704 kB
DirectMap1G: 110100480 kB
持续更新。。。

linux 内存使用分析的更多相关文章
- Linux内存技术分析(下)
Linux内存技术分析(下) 五.内存使用场景 out of memory 的时代过去了吗?no,内存再充足也不可任性使用. 1.内存的使用场景 page 管理 slab(kmalloc.内存池) 用 ...
- Linux内存技术分析(上)
Linux内存技术分析(上) 一.Linux存储器 限于存储介质的存取速率和成本,现代计算机的存储结构呈现为金字塔型.越往塔顶,存取效率越高.但成本也越高,所以容量也就越小.得益于程序访问的局部性原理 ...
- linux内存负载分析
衡量内存负载的一个很重要的指标就是页面置换的频率.当linux系统频繁的对页进行换进换出 的时候,说明物理内存不过,不得不进行频繁的置换页面. 使用vmstat(virtual memory stat ...
- 性能分析 | Linux 内存占用分析
这篇博客主要介绍 linux 环境下,查看内存占用的两种方式:使用 ps,top等命令:查看/proc/[pid]/下的文件.文章简要介绍了命令的使用方法与一些参数意义,同时对/proc/[pid]/ ...
- 利用Volatility对Linux内存取证分析-常用命令翻译
命令翻译 linux_apihooks - 检查用户名apihooks linux_arp - 打印ARP表 linux_aslr_shift - 自动检测Linux aslr改变 linux_ban ...
- linux内存占用分析
概述 想必在linux上写过程序的同学都有分析进程占用多少内存的经历,或者被问到这样的问题——你的程序在运行时占用了多少内存(物理内存)?通常我们可以通过top命令查看进程占用了多少内存.这里我们可以 ...
- 转: 关于Linux与JVM的内存关系分析
转自: http://tech.meituan.com/linux-jvm-memory.html Linux与JVM的内存关系分析 葛吒2014-08-29 10:00 引言 在一些物理内存为8g的 ...
- Linux与JVM的内存关系分析
引言 在一些物理内存为8g的server上,主要执行一个Java服务,系统内存分配例如以下:Java服务的JVM堆大小设置为6g,一个监控进程占用大约600m,Linux自身使用大约800m. 从表面 ...
- Linux与JVM的内存关系分析(转)
引言 在一些物理内存为8g的服务器上,主要运行一个Java服务,系统内存分配如下:Java服务的JVM堆大小设置为6g,一个监控进程占用大约600m,Linux自身使用大约800m.从表面上,物理内存 ...
随机推荐
- 数据库中间件分片算法之stringhash
前言 又是一个夜黑风高的晚上,带上无线耳机听一曲.突然很感慨一句话:生活就像心电图,一帆风顺就证明你挂了. 就如同我们干运维的,觉得很简单的事情,有时候能干出无限可能.还是言归正传吧,这一次我们来说说 ...
- 【题解】JXOI2018游戏(组合数)
[题解]JXOI2018游戏(组合数) 题目大意 对于\([l,r]\)中的数,你有一种操作,就是删除一个数及其所有倍数.问你删除所有数的所有方案的步数之和. 由于这里是简化题意,有一个东西没有提到: ...
- $Poj3017\ Cut\ The\ Sequence$ 单调队列优化$DP$
Poj AcWing Description 给定一个长度为N的序列 A,要求把该序列分成若干段,在满足“每段中所有数的和”不超过M的前提下,让“每段中所有数的最大值”之和最小. N<=10 ...
- Codeforces Round #524 (Div. 2)(前三题题解)
这场比赛手速场+数学场,像我这样读题都读不大懂的蒟蒻表示呵呵呵. 第四题搞了半天,大概想出来了,但来不及(中途家里网炸了)查错,于是我交了两次丢了100分.幸亏这次没有掉rating. 比赛传送门:h ...
- 不懂Neo4j?没关系,先学增删改查
从上篇文章中我们了解到了什么是Neo4j.为什么要用Neo4j.什么场景使用 以及怎么安装,如果您还不想熟悉,点击此处,传送过去哦~ 既然Neo4j是一个图数据库,那么毫无疑问,增删改查是必不可少的, ...
- hutool BigExcelWriter 下的autoSizeColumnAll异常问题
autoSizeColumnAll java.lang.IllegalStateException: Could not auto-size column. Make sure the column ...
- Ubuntu生成应用图标
1.DeskTop Entry介绍 现代 Linux 桌面系统也提供了此项功能.目前,Linux KDE 和 Linux GNOME 桌面系统都使用 Desktop Entry 文件标准来描述程序启动 ...
- 【转】C#中base关键字的几种用法:base()
转:https://blog.csdn.net/cplvfx/article/details/82982862 base其实最大的使用地方在面相对象开发的多态性上,base可以完成创建派生类实例时调用 ...
- ffmpeg参数编码大全
ffmpeg version N-49044-g89afa63 Copyright (c) 2000-2013 the FFmpeg developers built on Jan 19 2013 2 ...
- ConcurrentHashMap源码解析 JDK8
一.简介 上篇文章详细介绍了HashMap的源码及原理,本文趁热打铁继续分析ConcurrentHashMap的原理. 首先在看本文之前,希望对HashMap有一个详细的了解.不然看直接看Concur ...