Linux memory monitor 详解(3)

四、Linux 服务器的内存泄露和回收内存的方法
  1、内存泄漏的定义:
  一般我们常说的内存泄漏是指堆内存的泄漏。堆内存是指程序从堆中分配的,大小任意的(内存块的大小可以在程序运行期决定),使用完后必须显示释放的内存。应用程序一般使用malloc,realloc,new等函数从堆中分配到一块内存,使用完后,程序必须负责相应的调用free或delete 释放该内存块,否则,这块内存就不能被再次使用,我们就说这块内存泄漏了。
  2、内存泄露的危害
  从用户使用程序的角度来看,内存泄漏本身不会产生什么危害,作为一般的用户,根本感觉不到内存泄漏的存在。真正有危害的是内存泄漏的堆积,这会最终消耗尽系统所有的内存。从这个角度来说,一次性内存泄漏并没有什么危害,因为它不会堆积,而隐式内存泄漏危害性则非常大,因为较之于常发性和偶发性内存泄漏它更难被检测到。存在内存泄漏问题的程序除了会占用更多的内存外,还会使程序的性能急剧下降。对于服务器而言,如果出现这种情况,即使系统不崩溃,也会严重影响使用。
  3、内存泄露的检测和回收
  对于内存溢出之类的麻烦可能大家在编写指针比较多的复杂的程序的时候就会遇到。在 Linux 或者 unix 下,C、C++语言是最使用工具。但是我们的 C++程序缺乏相应的手段来检测内存信息,而只能使用 top 指令观察进程的动态内存总额。而且程序退出时,我们无法获知任何内存泄漏信息。
  使用kill命令
  使用Linux命令回收内存,我们可以使用Ps、Kill两个命令检测内存使用情况和进行回收。在使用超级用户权限时使用命令“Ps”,它会列出所有正在运行的程序名称,和对应的进程号(PID)。Kill命令的工作原理是:向Linux操作系统的内核送出一个系统操作信号和程序的进程号(PID)。
  应用例子:
为了高效率回收内存可以使用命令ps 参数v:
[root@ ~]# ps v
 PID TTY      STAT   TIME MAJFL   TRS   DRS   RSS %MEM COMMAND
 2542 tty1     Ss+    0:00      0     8 1627   428 0.1 /sbin/mingetty tty1
 2543 tty2     Ss+    0:00      0     8 1631   428 0.1 /sbin/mingetty tty2
 2547 tty3     Ss+    0:00      0     8 1631   432 0.1 /sbin/mingetty tty3
 2548 tty4     Ss+    0:00      0     8 1627   428 0.1 /sbin/mingetty tty4
 2574 tty5     Ss+    0:00      0     8 1631   432 0.1 /sbin/mingetty tty5
 2587 tty6     Ss+    0:00      0     8 1627   424 0.1 /sbin/mingetty tty6
 2657 tty7     Ss+    1:18     12 1710 29981 7040 3.0 /usr/bin/Xorg :0 -br -a
 2670 pts/2    Ss     0:01      2   682 6213 1496 0.6 -bash
 3008 pts/4    Ss     0:00      2   682 6221 1472 0.6 /bin/bash
 3029 pts/4    S+     0:00      2    32 1783   548 0.2 ping 192.168.1.12
 3030 pts/2    R+     0:00      2    73 5134   768 0.3 ps v
  然后如果想回收Ping命令的内存的话,使用命令:
  # Kill -9 3029
  使用工具软件
  Memprof是一个非常具有吸引力且非常易于使用的软件,它由Red Hat的Owen Talyor创立。这个工具是用于GNOME前端的Boehm-Demers-Weiser垃圾回收器。这个工具直接就可以执行,并且其工作起来无需对源代码进行任何修改。在程序执行时,这个工具会以图形化的方式显示内存的使用情况。

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/9cdbde66a3cf487f8bdd5cff83c7143e.html