免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 895 | 回复: 0
打印 上一主题 下一主题

[转载]Redhat 官方对于 Linux 内存使用的解释 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-08-28 08:21 |只看该作者 |倒序浏览

    我的系统显示已经使用了大量的内存,我想存在内存泄漏。Linux核心在内存中怎么处理缓存,缓存在top或者free的输出中是怎么显示的?

解决方法:
    Linux的基本原则是没有资源应该被浪费。因此核心会使用尽可能多的RAM,来缓存来自本地和远程的文件系统的信息。系统做读写操作的时候,会将与当前运行的进程相关的数据尽量存储在RAM里。系统报告的缓存是缓冲和页缓存两者之和。缓存并不是在进程结束的时候被回收(你可能很快会启动另外一个进程,需要同样的数据),而是随需回收--比如,当你启动一个需要大量内存的进程时,Linux核心会从内存中回收缓存,将得到的内存分配给新的进程。
    有些区域,比如匿名内存映射(mmps)和共享内存区域,它们被报告为缓存,但不是被核心直接释放。一般的缓存不映射到进程的地址空间,仅仅是简单的核心映射,而这些特别的缓存映射到所有挂接到它们上面的进程。
下面是一个例子(单位是MB):
# free -m
             total       used       free     shared    buffers     cached
Mem:          1000        900        100          0        350        350
-/+ buffers/cache:        200        800
在这里例子中,应用程序只使用了200MB内存,还有800MB空闲内存可以使用。
需要注意的条目:
物理已用内存 = 实际已用内存 + 缓冲 + 缓存
物理空闲内存 = 总物理内存 - 实际已用内存 - 缓冲 - 缓存
应用程序可用空闲内存 = 总物理内存 - 实际已用内存
应用程序已用内存 = 实际已用内存 - 缓冲 - 缓存
© 2008 Red Hat, Inc. All rights reserved. Red Hat is a registered trademark of Red Hat, Inc. All other names and trademarks are the property of their respectove owners.
About Red Hat
  :  
Legal statement
  :  
Privacy statement
  :  
Contact Red Hat


原文地址
http://www.redhat.com.cn/kbase/705.php



本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/7362/showart_1150666.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP