os内存使用管理之linux篇

原创 2013年12月02日 21:45:50


os内存使用管理之linux篇


看一下LINUX内存机制是怎么运作的,了解了基础知识,对于理解和操作是有很大帮助的。

 抛砖引玉:
Linux 优先使用物理内存,当物理内存还有空闲时,linux是不会施放内存的,即时占用内存的程序已经

被关闭了(这部分内存就用来做缓存了)。也就是说,即时你有2G的内存,用过一段时间后,也会被占满

。这样做的好处是,启动那些刚开启过的程序、或是读取刚存取过得数据会比较快,对于服务器很有好处

 你可以用 free 指令查看一下输出,用 used 减去 buffer 和 cache,才是你运行中的程序所占用的空

间,举例如下:

        total     used      free    shared   buffers    cached

 Mem:   516300   504264     12036     0       88396    236792
 -/+ buffers/cache: 179076 337224
 Swap: 1544184 21276 1522908

 504264 - 88396 - 236792 = 179076

也就是说目前正在被使用的内存只有 179 兆。不要被 504兆的used吓住了。

windows则总是给内存留下一定的空闲空间,即时内存有空闲也会让程序使用一些虚拟内存,这样做的好

处是,启动新的程序比较快,直接分给它些空闲内存就可以了,而linux下呢?由于内存经常处于全部被

使用的状态,则要先清理出一块内存,再分配给新的程序使用,因此,新程序的启动会慢一些。

 另外,内存是随机访问的,也就是说,无论你的内存占用了多少,数据的存取时间都是相同的,跟硬盘

不同。


linux 内存使用高原因  2009-09-05 10:40:02|  分类: Linux |  标签: |字号大

小 订阅
linux 机子新装内存used偏高...
往往给出这样的结果,怀疑内存用了90%:
Mem: 4146788k total, 3825536k used, 321252k free, 213488k buffers
Swap: 2650684k total, 80k used, 2650604k free, 3006404k cached

这样怀疑很普遍,因为很多人用惯了Windows。Windows下,可以使用任务管理器查看当前进程对于内存的

消耗情况。在我看来,Windows物理内存总是留下一定的空间,就算此时物理内存有空闲时,也会让某些

程序去使用虚拟内存,目的是在Windows下启动新程序时,直接分配空闲的物理内存,这样子新程序启动

速度就较快,而Linux则不然。

而在Linux下,使用top命令看到内存占用情况:

Mem: 4146788k total, 3825536k used, 321252k free, 213488k buffers
Swap: 2650684k total, 80k used, 2650604k free, 3006404k cached


这里的结果显示使用了3.8G的used,占用率达到90%。看看free的结果你还可以对比一下:
$ free -m
     total used free shared buffers cached
Mem: 4049  3784 265   0       208   2939
-/+ buffers/cache: 636 3413
Swap: 2588 0 2588

虽然MEM显示了3.7G左右的used,但是(-/+ buffers/cache)减去buffers和cache的结果可以看到,当前

进程实际占用内存是636M,而可用空闲(free)内存为3.4G。


可以这么理解:在linux的内存分配机制中,优先使用物理内存,当物理内存还有空闲时(还够用),不

会释放其占用内存,就算占用内存的程序已经被关闭了,该程序所占用的内存用来做缓存使用,对于开启

过的程序、或是读取刚存取过得数据会比较快。

如上面的例子:使用了4G的内存,3.7G被占用,但是buuffer和cached部分作为缓存,可以使用命中率的

方式提高使用效率,而且这部分缓存是根据指令随时可以释放的,我们可以认为这部分内存没有实际被使

用,也可以认为它是空闲的。

因此查看目前进程正在实际被使用的内存,是used-(buffers+cache),也可以认为如果swap没有大量使用

,mem还是够用的,只有mem被当前进程实际占用完(没有了buffers和cache),才会使用到swap的。


未完待补充。。。。。。。


以上整理来之网上。

相关文章推荐

嵌入式实时操作系统μC/OS-||原理及应用学习6----动态内存管理

1.μC/OS-||对内存进行两级管理,即把一个连续的内存空间分为若干个分区,每个分区又分为若干个大小相等的内存块。操作系统以分区为单位来管理动态内存,而任务以内存块为单位来获得和释放动态内存。内存分...

iOS与OS X多线程和内存管理(英文版)

  • 2014年03月04日 17:50
  • 6.02MB
  • 下载

《Objective-C 高级编程 iOS与OS X多线程和内存管理》 核心札记二

核心札记二   Blocks   阅读地点:北京 肯德基店  2014.4.7 1,Blocks 是C 语言的扩充功能,用一句话概述就是:带有自动变量(局部变量,作者将此翻译成自动变...

Mac OS 内存管理知识

先请看下面三张图片,是MAC OS系统的“活动监视器”的截图,分别是8G,4G,2G内存。             使用Mac OS系统时,关注内存的使用情况有时是必要的。 ...
  • elf8848
  • elf8848
  • 2014年10月09日 10:44
  • 381
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:os内存使用管理之linux篇
举报原因:
原因补充:

(最多只允许输入30个字)