首页 > 技术文档 > Linux > Linux内存管理方法
2013
09-16

Linux内存管理方法

  在 Linux 或者其他 Unix 内核的系统中我们通常可以使用 top 命令来查看服务器 CPU 与内存的占用情况,下面北街来分别举例给各位朋友看看,有需要了解的朋友可进入参考。

  一、top
  # top -d 1 -p pid //设置为delay 1s,默认是delay 3s
  如果想根据内存使用量进行排序,可以shift + m(Sort by memory usage)

  二、pmap
  # pmap -d 14596 //可以根据进程查看进程相关信息占用的内存情况,(进程号可以通过ps查看)
  # pmap pid

  三、ps
  # ps -e -o ‘pid,comm,args,pcpu,rsz,vsz,stime,user,uid’ //其中rsz是实际内存由大到小排序
  # ps -e -o ‘pid,comm,args,pcpu,rsz,vsz,stime,user,uid’ | grep oracle | sort -nrk5
  # ps aux | grep process_name

  四、free

     total used free shared buffers cached
Mem:       3266180  3250004 16176 0   110652  2668236
-/+ buffers/cache: 471116  2795064
Swap:       2048276 80160  1968116

total:总计物理内存的大小
used:已使用多大
free:可用有多少
Shared:多个进程共享的内存总额
Buffers/cached:磁盘缓存的大小

  我们通过 free 命令查看机器空闲内存时,会发现 free 的值很小。这主要是因为,在 linux 中有这么一种思想,内存不用白不用,因此它尽可能的 cache 和 buffer 一些数据,以方便下次使用。但实际上这些内存也是可以立刻拿来使用的。

  所以空闲内存=free+buffers+cached=total-used

  Mem 和 -/+ buffers/cache 的区别
  Mem 是从 OS 的角度来看,因为对于OS,buffers/cached 都是属于被使用,所以他的可用内存是 16176KB,已用内存是 3250004KB,其中包括,内核(OS)使用 +Application(X,oracle,etc) 使用的 +buffers+cached。

  -/+ buffers/cache 所指的是从应用程序角度来看,对于应用程序来说,buffers/cached 是等于可用的,因为 buffer/cached 是为了提高文件读取的性能,当应用程序需在用到内存的时候,buffer/cached会很快地被回收。

  占用内存的测量
  测量一个进程占用了多少内存,Linux 为我们提供了一个很方便的方法,/proc 目录为我们提供了所有的信息,实际上 top 等工具也通过这里来获取相应的信息。

/proc/meminfo 机器的内存使用信息
/proc/pid/maps pid为进程号,显示当前进程所占用的虚拟地址。
/proc/pid/statm 进程所占用的内存

# cat /proc/self/statm

最后编辑:
作者:北街
身高八尺,腰围也是八尺!
捐 赠如果您觉得这篇文章有用处,请支持作者!鼓励作者写出更好更多的文章!

Linux内存管理方法》有 3 条评论

  1. 康妮妃 说:

    水平很高啊,值得学习

  2. 起重配件 说:

    支持一下博主

  3. 微历史(weilishi.com.cn) 说:

    我表示看不懂,一直被windows奴役

留下一个回复

你的email不会被公开。