- 浏览: 479539 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
alvin198761:
renzhengzhi 写道我参与过12306余票查询系统的开 ...
别给12306 辩解了 -
renzhengzhi:
我参与过12306余票查询系统的开发,用户请求被前面3层缓存拦 ...
别给12306 辩解了 -
renzhengzhi:
写的很好。
JAVA线程dump的分析 -
liyonghui160com:
说好的附件呢
分布式服务框架 Zookeeper -- 管理分布式环境中的数据 -
ghpaas:
orbeon作为xforms标准的实现,不论其设计器还是运行时 ...
XForms 1.1 中文翻译—第1章 关于XForms标准
Terms
VSS - Virtual Set Size 虚拟耗用内存(包含共享库占用的内存)
RSS - Resident Set Size 实际使用物理内存(包含共享库占用的内存)
PSS - Proportional Set Size 实际使用的物理内存(比例分配共享库占用的内存)
USS - Unique Set Size 进程独自占用的物理内存(不包含共享库占用的内存)
一般来说内存占用大小有如下规律:VSS >= RSS >= PSS >= USS
Overview
The aim of this post is to provide information that will assist in interpreting memory reports from various tools so the true memory usage for Linux processes and the system can be determined.
Android has a tool called procrank (/system/xbin/procrank), which lists out the memory usage of Linux processes in order from highest to lowest usage. The sizes reported per process are VSS, RSS, PSS, and USS.
For the sake of simplicity in this description, memory will be expressed in terms of pages, rather than bytes. Linux systems like ours manage memory in 4096 byte pages at the lowest level.
VSS (reported as VSZ from ps) is the total accessible address space of a process. This size also includes memory that may not be resident in RAM like mallocs that have been allocated but not written to. VSS is of very little use for determing real memory usage of a process.
RSS is the total memory actually held in RAM for a process. RSS can be misleading, because it reports the total all of the shared libraries that the process uses, even though a shared library is only loaded into memory once regardless of how many processes use it. RSS is not an accurate representation of the memory usage for a single process.
PSS differs from RSS in that it reports the proportional size of its shared libraries, i.e. if three processes all use a shared library that has 30 pages, that library will only contribute 10 pages to the PSS that is reported for each of the three processes. PSS is a very useful number because when the PSS for all processes in the system are summed together, that is a good representation for the total memory usage in the system. When a process is killed, the shared libraries that contributed to its PSS will be proportionally distributed to the PSS totals for the remaining processes still using that library. In this way PSS can be slightly misleading, because when a process is killed, PSS does not accurately represent the memory returned to the overall system.
USS is the total private memory for a process, i.e. that memory that is completely unique to that process. USS is an extremely useful number because it indicates the true incremental cost of running a particular process. When a process is killed, the USS is the total memory that is actually returned to the system. USS is the best number to watch when initially suspicious of memory leaks in a process.
For systems that have Python available, there is also a nice tool called smem that will report memory statistics including all of these categories.
# procrank
procrank
PID Vss Rss Pss Uss cmdline
481 31536K 30936K 14337K 9956K system_server
475 26128K 26128K 10046K 5992K zygote
526 25108K 25108K 9225K 5384K android.process.acore
523 22388K 22388K 7166K 3432K com.android.phone
574 21632K 21632K 6109K 2468K com.android.settings
521 20816K 20816K 6050K 2776K jp.co.omronsoft.openwnn
474 3304K 3304K 1097K 624K /system/bin/mediaserver
37 304K 304K 289K 288K /sbin/adbd
29 720K 720K 261K 212K /system/bin/rild
601 412K 412K 225K 216K procrank
1 204K 204K 185K 184K /init
35 388K 388K 182K 172K /system/bin/qemud
284 384K 384K 160K 148K top
27 376K 376K 148K 136K /system/bin/vold
261 332K 332K 123K 112K logcat
33 396K 396K 105K 80K /system/bin/keystore
32 316K 316K 100K 88K /system/bin/installd
269 328K 328K 95K 72K /system/bin/sh
26 280K 280K 93K 84K /system/bin/servicemanager
45 304K 304K 91K 80K /system/bin/qemu-props
34 324K 324K 91K 68K /system/bin/sh
260 324K 324K 91K 68K /system/bin/sh
600 324K 324K 91K 68K /system/bin/sh
25 308K 308K 88K 68K /system/bin/sh
28 232K 232K 67K 60K /system/bin/debuggerd
#
发表评论
-
使用 RPM 打包软件,第 1 部分: 构建和分发包
2012-03-26 10:31 1252顾名思义,开源软件 ... -
用 RPM 打包软件,第 3 部分
2012-03-26 10:30 1151安装和卸载脚本的工作原理 安装和卸载脚本看起来很简单, ... -
用 RPM 打包软件,第 2 部分
2012-03-26 10:28 1151不作为 root 用户来构建 RPM 包 正如您在第 1 ... -
用 RPM 打包软件,第 1 部分
2012-03-26 10:23 976RPM(Red Hat Package Manager)是用于 ... -
Memory usage analysis
2010-09-03 23:33 1209Memory usage analysis Syste ... -
Linux: How to measure actual memory usage of an application or process?
2010-09-03 23:31 1275http://stackoverflow.com/questi ... -
HowTo: Profile Memory in a Linux System
2010-09-03 22:56 1177HOWTO: Profile Memory in a Li ... -
Linux内存管理机制
2010-09-03 22:48 2083内存是Linux内核所管理的最重要的资源之一,内存管理 ... -
linux内存管理概述
2010-09-03 22:44 2442Linux中的地址空间(一)有这么一系列的问题,是否在困扰 ... -
linux上buffer和cache的区别
2010-09-03 15:14 1519free free 命令相对于top 提供了更简洁的查看系统 ... -
linux下top命令参数解释
2010-09-03 14:56 864top命令是Linux下常用的性能分析工具,能够实时显示系统中 ... -
smem memory reporting tool
2010-08-25 15:41 966smem is a tool that can give ... -
Linux进程虚拟内存和物理内存
2010-08-25 15:39 5047先介绍几个基本概念: SIZE: 进程使用的 ... -
Linux 内核的文件 Cache 管理机制介绍
2010-08-18 18:21 10481 前言 自从诞生以来,Linux 就被不断完善和普及 ... -
运行时: 块内存复制,第 2 部分
2010-08-06 12:33 1230我的 前一专栏专注于 ... -
RunTime: 块内存复制
2010-08-06 12:32 1178内存复制 在计算机中,内存复制经常而普遍。它们出现在联网 ... -
内存详解
2010-08-06 11:34 930文档选项 ... -
Linux slab 分配器剖析
2010-08-06 11:32 1309良好的操作系统性能部分依赖于操作系统有效管理资源的能力。在 ... -
降低 Linux 内存开销
2010-08-06 11:30 1099Linux 广受追捧的一个优点是它比 Microsoft® ... -
在 Linux 平台中调试 C/C++ 内存泄漏方法
2010-08-06 11:29 1814由于 C 和 C++ 程序中完全由程序员自主申请和释放内存 ...
相关推荐
MPPT_10kHz_PWM_P&O:以 10 khz 实现 P&O 算法MPPT_10kHz_PWM_VSS-P&O:10 kHz 可变步长 P&O 算法的实现MPPT_1kHz_PWM_M-VSS-P&O:使用 1 khz 实现修正的可变步长 P&O 算法MPPT_10kHz_PWM_M-VSS-P&O:使用 10 khz ...
- **VSS Plugin**:版本控制系统插件。 - **Implementors**:帮助跳转到方法的实现类。 - **CallHierarchy**:展示方法调用层次。 - **Eclipse Tidy**:检查和格式化HTML/XML文件。 - **Checkclipse**:检查代码风格...
Vss2Git is a Windows GUI application that exports all or parts of an existing Microsoft Visual SourceSafe 6.0 (VSS) (Wikipedia) repository to a new Git repository. It attempts to construct meaningful ...
- **VSS Plugin**:为 Eclipse 提供 VSS 版本控制系统的集成。 **下载地址**:[http://sourceforge.net/projects/vssplugin](http://sourceforge.net/projects/vssplugin) #### 17. Implementors - Provides ...
- **功能**:Memory Manager 用于监控和管理 Eclipse 的内存使用。 - **特点**:帮助开发者优化内存占用。 **下载地址**:[http://cloudgarden.com/memorymanager/](http://cloudgarden.com/memorymanager/) --- ...
- **功能简介**:Memory Manager插件可以监控Eclipse的内存使用情况,帮助开发者发现潜在的内存泄漏等问题。 ##### 25. SWT Designer,Java GUI设计工具 - **下载地址**:[http://www.swt-designer.com/]...
NULL 博文链接:https://lindows.iteye.com/blog/512414
More:介绍及文档:https://material.vss.imGithub: https://github.com/viosey/hexo-theme-materialDemo: 访问我的博客实时预览 Paradox 样式:Viosey's Blog:https://blog.viosey.comIsolation 样式 Demo:...
7. **VSS Plugin**:VSS客户端插件,适用于版本管理。下载地址:[http://sourcefore.net/projects/vssplugin](http://sourcefore.net/projects/vssplugin)。 8. **Implementors**:追踪方法代码时,可以转到方法的...
vss2005 vss传SVN(不支持),支持vss转git, 源码来源于:https://github.com/trevorr/vss2git(只负责编译好,没有改一行代码;本次编译代码的版本号为:099cb72(2021年4月27日),版本代码地址:...
**简介**:VSS Plugin为Eclipse提供了对Visual SourceSafe (VSS) 版本控制系统的支持,允许开发者在Eclipse环境中直接进行版本管理和协同开发。 #### 十二、Implementors **名称**:Implementors **链接**:...
在探讨HTML网页加载中的`<iframe>`元素时,我们首先需要理解`<iframe>`的基本概念、属性及其在网页设计中的作用。本篇文章将围绕提供的代码片段`...
VSS,全称为Visual SourceSafe,是由微软公司开发的一款源代码版本控制系统,广泛应用于软件开发团队的协同工作和代码管理。本次公司培训主要围绕VSS的使用和配置展开,通过三个PPT,我们可以深入理解其核心功能和...
它可以替代CVS,VSS等轻量级版本控制工具,它支持Local和Web(Apache)两种工作方式,并且最关键就是完全免费的。 在组织团队开发时,除了服务器端的工具之外,客户端也需要相应的工具才能访问源码库。而且,最好...
微软的Visual SourceSafe(VSS)是一款专为软件应用程序团队开发设计的版本控制系统。版本控制系统的存在是为了解决在多人协作开发过程中可能出现的问题,确保团队成员可以安全地同时修改代码,而不会相互冲突或丢失...
- **备注**:ARTiSAN Studio是一个功能全面的建模工具,支持多种编程语言和开发环境,同时还可以与其他版本控制系统(如PVCS、VSS、ClearCase、CMSynergy)集成,适用于大型复杂项目的开发和管理。 #### Astah UML ...