使用valgrind工具检测server端lib库的内存泄漏
工作中需要检查内存泄漏,但是Linux server端的代码生成的是lib库,而不是可执行程序。研究了很久,分享给有需要的朋友。
背景,server端code是C++开发的,部署在Linux上的lib库集合;客户端是WPF,通过tibco RV call server端的接口,执行命令。
网上找到的资料都是通过gcc编译成可执行的程序,再通过valgrind命令检测内存泄漏。因此尝试gcc编译时去掉-c选项,但是根本编译不过,因为server端根本不是可执行代码,而是lib库。几经波折,终于通了。方法如下:
1. 服务器上安装valgrind
yum install valgrind
安装成功,通过命令valgrind --version查看valgrind的版本;通过命令gcc --version查看gcc版本
2. 编译server端代码
server端编译c++代码,肯定是有Makefile文件的。查看makefile文件的编译命名是否有-g选项,没有则加上。范例(执行make指令,会打印出编译过程中的中间指令,检查是否有-g选项)
gcc -m64 -fPIC -Wno-deprecated -Wno-invalid-offsetof -DLINUX64 -DBITS64 -c -g -fpermissive -DLINUX64 -DBITS64 -DONEBYTE -DRW_STD_TYPEDEFS -D_FASTECH_ -D__MBX_DISTRIB__ -DNOEXTERNC -I./Fwlinux64.d -I. -I../../../include/Fwlinux64.d -I../../../include -I../../../Fwlinux64.d/include -I/home/product/v1.0/FASTech/FACTORYworks/include/Fwlinux64.d -I/home/product/v1.0/FASTech/FACTORYworks/include -I/home/product/v1.0/FASTech/SDT/include -I/home/ProdustSource/v1.0/server/include/Fwlinux64.d -I/home/ProdustSource/v1.0/server/include -I/home/product/v1.0/FASTech/FACTORYworks/include -DFAB32 jobprep.cpp
3. 起server
4. 停某支进程(需要检查内存泄漏的那支进程)
5. 通过valgrind命令起item4停掉的进程
log能正常打印出来(可有可无,原本server的执行过程会打印到相应的log文件中),命令如下:
CELLtrace -n FW_MBX_DEV_srv1 -f /home/systemlog/FW_MBX_DEV.srv1_log -s -T -d -S 20000000 -B 50 -X &
valgrind起进程,命令如下:
valgrind --leak-check=full --show-leak-kinds=all --track-origins=yes --log-file=test.log DTPFsrv "set mbx=FW_MBX_DEV" "set name=srv1.1" "set dblog=TRC:FW_MBX_DEV_srv1" "set dbuser=fwdev dbpassword=fwdev dbserver=MESDSRV dbtimeout=30 dbretries=200 trace_name=FW_MBX_DEV_srv1 verbose=5 diagnose=5" "include /home/Prod/config/srv1.cfg"
6. 在客户端执行相应进程负责的功能,然后去test.log文件查看valgrind打印出来的检测报告。