我们都知道进程运行时,会有一个栈空间(stack)和一个堆空间(heap), 栈空间用于函数调用和局部变量,堆空间是C语言的 malloc 来分配的全局指针。这些都是进程的私有数据,除了这些,还有映射进来的动态库,进程间的共享内存等共享空间。另外,操作系统还支持预留虚拟地址空间的功能(延迟分配),也就是在读写该内存的时候,操作系统才进行物理内存的分配,因此进程占用的空间情况还是比较复杂的。下面简单地说明一下。

Linux

VSZ:Virtual Memory Size(虚拟内存大小)。进程占用的全部地址空间,共享库,预分配内存,交换分区等都包含在里面。因此,它远远大于实际的占用的内存空间。

RSS:Resident Set Size(驻留集大小), 实际占用的物理内存,它包含共享库,但不包含在交换分区的空间。随着程序的运行,RSS也会跟着增长,VSZ将是它的上限。

PSS:Proportional Set Size, 也是实际分配的物理内存,与RSS的区别是,它以平分的方式来计算共享库的大小(共享库 / 进程个数), RSS会把共享库的大小全部计算进来。

USS:Unique Set Size, 进程的私有内存(独自使用的库,堆等空间),不包含共享的内存空间。

ANON: Anonymous memory,匿名内存 —— 没有文件关联的内存页面。Linux会自动映射文件到内存,读取的文件后,会自动缓存到内存。如果,应用程序只是使用mmap(MAP_ANONYMOUS) 分配一些内存页面没有文件关联,就称为“匿名内存”。

Dirty: dirty pages , 脏页大小 —— 还没有写回到硬盘的缓存页面。

VIRT: 同VSZ。

RES: 同RSS。

假如进程A(2k),只依赖动态库B(1000k) ;A 分配 128k的匿名空间,200k的堆栈和堆的空间——实际使用100k。其中动态库B被 2个进程共享,实际加载200k,那么 ——

VSZ = 2k + 1000k + 128k + 200k = 1230k

RSS = 2k + 200k + 128k + 100k = 430k

PSS = 2k + 200k / 2 + 128k + 100k = 330k

USS = 2k + 128k + 100k = 230k

ANON = 128k

工具

进程的内存原始数据的主要来源于 proc 目录下的2个文件,可以 直接cat 查看。

  1. /proc/{$PID}/smaps

  2. /proc/{$PID}/maps

maps 是以地址空间段来输出内容,而 smaps 则以文件,堆,堆栈来组织内容。

1: ps aux

单独查看某个进程

2: top

3: pmap -[x/X/XX] {$PID}

x 越大,越多,信息越详细。

4: smem

Windows

windows 有一个 [reserve/commit] 的概念,VirtualAlloc 可以预先保留一个连续的虚拟内存空间,实际上没有内存分配。当需要使用的时候,再次使用 VirtualAlloc 去提交(commit)需要使用的区域,当这个内存区域被读写的时候,操作系统才进行内存分配。 因此,commit空间一般偏大。

进程正在使用的物理内存称为工作集(working set),分为私有工作集和共享工作集。可执行程序在运行过程中分配的内存,称为私用内存。如果再加上文件cache,dll等共享内存(page file),就是进程使用的全部物理内存——工作集。工作集不包含交换分区,只是当前被分配的物理内存,而私有数据则包含交换分区的内容 —— 假如:有10M的私有数据,8M被换出,那么工作集只把还在内存里的2M大小计算在内。

进程的虚拟内存空间又称为“Commit Size Limit, 它的大小有两种计算方式:

  • Total Virtual Memory = Total Physical + Page File Size

  • Total Virtual Memory = Committed (Virtual In Use) + Available Virtual Memory

Vmmap是windows官方提供的一个工具,下图是软件的窗口, WS即 工作集,任务管理器里显示的是Private WS(专用工作集)的值。

Size: 软件向操作系统申请的最大物理内存空间,OS在使用时才分配,因此进程实际占用的空间会比这个值小,但在使用过程中,占用空间可能会一直增加。

Committed: 已提交到OS 的内存空间,读写内存页面时分配,上限是 Size。

Total WS = Private WS + Shareable WS 。

---
欢迎大家来我的公众号交流: 般若程序蝉

进程的内存占用情况分析相关推荐

  1. java对象内存占用情况分析

    一个对象实例占用了多少字节,消耗了多少内存?这样的问题在c或c++里使用sizeof()方法就可以得到明确答案,在java里好像没有这样的方法(java一样可以实现),不过通过jmap工具倒是可以查看 ...

  2. Shell - 监控某个进程的内存占用情况、主机CPU、磁盘空间等信息以及守护进程

    文章目录 脚本 启动的两种方式 方式一 注册到系统Cron 方式二 运行结果 linux内存.cpu.磁盘IO 脚本 #!/bin/sh ############################## ...

  3. java内存占用分析_JVM内存占用情况深入分析

    本文转自阿飞的博客 很多同学都问过这个问题,为什么我的Xmx设置4g,但是TOP命令查询RES却占用5G,6G,甚至10G.这个正常吗?也可以说正常,也可以说不正常,怎么判断?笔者今天就要为你解答这个 ...

  4. Shell脚本和Python查看Nginx并发连接数、进程数和常驻内存占用情况

    Shell脚本查看Nginx并发连接数.进程数和常驻内存占用情况 http://xiaoyongxing1.blog.163.com/blog/static/642807522015144302240 ...

  5. 检测指定进程的CPU和内存占用情况

    '检测指定进程的CPU和内存占用情况'vs2019 vb.net Dim Name = Process.GetCurrentProcess().ProcessNameDim cpuCounter = ...

  6. JVM内存占用情况深入分析,分分钟解开你的疑惑

    很多同学都问过这个问题,为什么我的Xmx设置4g,但是TOP命令查询RES却占用5G,6G,甚至10G.这个正常吗?也可以说正常,也可以说不正常,怎么判断?笔者今天就要为你解答这个问题,叫你如何分析J ...

  7. linux 省内存的桌面,Linux_在Linux中可视化显示内存占用情况的方法,物理内存不足对Linux桌面系统 - phpStudy...

    在Linux中可视化显示内存占用情况的方法 物理内存不足对Linux桌面系统和服务器系统的性能影响都很大.当你的计算机变慢时,要做的第一件事就是释放内存.尤其是在多用户环境以及执行关键任务的服务器环境 ...

  8. linux 系统显示很大,在Linux中可视化显示内存占用情况的方法

    物理内存不足对Linux桌面系统和服务器系统的性能影响都很大.当你的计算机变慢时,要做的第一件事就是释放内存.尤其是在多用户环境以及执行关键任务的服务器环境下,内存消耗会变得更加关键,因为多个用户和应 ...

  9. 如何查看服务器资源占用情况,云服务器如何查看内存占用情况

    云服务器如何查看内存占用情况 发布时间:2020-05-26 15:28:18 来源:亿速云 阅读:508 作者:栢白 云服务器如何查看内存占用情况?云 我们以 Linux 云服务器为例,介绍几个常用 ...

最新文章

  1. 2018湖湘杯海选复赛Writeup
  2. filter---用angularjs实现关键字高亮
  3. 各个国家的市场分析(摩洛哥,德国)
  4. l298n电机哪一端为正_一文详解电机倒顺开关接法!
  5. .NET实现应用程序登录Web页
  6. ehcache 清除缓存_如何设计一个本地缓存
  7. Adobe illustrator 调整图例为2列 - 连载 16
  8. mysql生产应用_MySQL备份利器之Xtrabackup--生产应用
  9. linux dd 光标在闪,linux dd详解
  10. 蓝桥杯2015年第六届C/C++省赛A组第八题-饮料换购
  11. 高德地图在android上的开发汇总
  12. html5轮播图代码效果图,JavaScript实现轮播图效果代码实例
  13. java 判断文章的重复率_如何统计文件重复率
  14. 计算机中字符的表示方法
  15. 建筑智能化资质办理要求
  16. Minix进程间通信分析
  17. go-redis 使用
  18. 你不再需要动态网页——编辑-发布-开发分离
  19. python线程死锁的原因,浅谈Python线程的同步互斥与死锁
  20. (Java)通讯录的实现

热门文章

  1. java actionlistener_java 鼠标事件监听ActionListener
  2. 计算机模拟天体的原理,天体物理学中动力学研究的计算机模拟.PDF
  3. 《给忙碌者的天体物理学》简单的概念地图
  4. Python的三层架构(基础篇)
  5. sshd服务设定root登陆配置项PermitRootLogin的解析
  6. 【转】QQ OutLook设置
  7. Trunk口配置实验
  8. PWM电压型同步Buck系统
  9. Grub2引导Grub4dos菜单写法
  10. 滚动锁定 scroll lock 键有什么用?