四、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@www~]#psvPIDTTYSTATTIMEMAJFLTRSDRSRSS%MEMCOMMAND2542tty1Ss+0:000816274280.1/sbin/mingettytty12543tty2Ss+0:000816314280.1/sbin/mingettytty22547tty3Ss+0:000816314320.1/sbin/mingettytty32548tty4Ss+0:000816274280.1/sbin/mingettytty42574tty5Ss+0:000816314320.1/sbin/mingettytty52587tty6Ss+0:000816274240.1/sbin/mingettytty62657tty7Ss+1:181217102998170403.0/usr/bin/Xorg:0-br-a2670pts/2Ss0:012682621314960.6-bash3008pts/4Ss0:002682622114720.6/bin/bash3029pts/4S+0:0023217835480.2ping192.168.1.123030pts/2R+0:0027351347680.3psv然后如果想回收Ping命令的内存的话,使用命令:
#Kill-93029
使用工具软件
Memprof是一个非常具有吸引力且非常易于使用的软件,它由RedHat的OwenTalyor创立。这个工具是用于GNOME前端的Boehm-Demers-Weiser垃圾回收器。这个工具直接就可以执行,并且其工作起来无需对源代码进行任何修改。在程序执行时,这个工具会以图形化的方式显示内存的使用情况。