1、valgrind
valgrind安装:参考: https://blog.csdn.net/justheretobe/article/details/52986461
wegit:http://valgrind.org/downloads/valgrind-3.12.0.tar.bz2
tar -jxvf valgrind-3.12.0.tar.bz2
cd valgrind-3.12.0
./configure
make
sudo make install
输入valgrind–h显示valgrind的参数及提示,说明安装成功
luajit问题:参考https://groups.google.com/forum/#!topic/openresty/riEO_YXTwz4
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 |
|
解决的办法是使用 openresty 的 luajit 仓库的 v2.1-agentzh 分支重新: https://github.com/openresty/luajit2/tree/v2.1-agentzh ,然后,重新编译一个特殊版本的 LuaJIT,强制它使用系统的分配器,即在编译 LuaJIT 时使用类似下面的命令: make CCDEBUG=-g Q= XCFLAGS='-DLUAJIT_USE_VALGRIND -DLUAJIT_USE_SYSMALLOC'
编译脚本做下面的修改:
export LUAJIT_INC=/usr/local/include/luajit-2.1
nginx处理请求都是在worker进程中,如果不特殊配置valgrind只检测master进程的信息,可以配置下面的样子,设置worker进程启动:
worker_processes 1;
daemon off;
master_process off;
或者使用在valgrind中使用–trace-children=yes 选项跟踪子进程信息
启动方式
sudo valgrind --tool=memcheck ./sbin/nginx -p . -c conf/配置文件.conf
或以日志形式记录
sudo valgrind --log-file=./valgrind_report.log --leak-check=full --show-leak-kinds=all --show-reachable=no --track-origins=yes --trace-children=yes ./sbin/nginx -p . -c conf/main.conf
2、asan
(1)适配代码:
编译脚本中添加:
--fsanitize=address -fno-omit-frame-pointer -static-libasan
--with-ld-opt="-fsanitize=address -static-libasan"
makefile中添加 :-fsanitize=address -fno-omit-frame-pointer -static-libasan
nginx本身需要适配一些文件,不然,会误认为是内存泄漏。
修改下面的文件:
modified: libs/libwtf/GNUmakefile
modified: libs/protobuf/Makefile
modified: src/core/nginx.h
modified: src/core/ngx_array.c
modified: src/core/ngx_array.h
modified: src/core/ngx_palloc.c
modified: src/core/ngx_palloc.h
(2)安装clang
(3)编译新版本运行起来,然后查看日志
默认情况下,asan遇到内存问题,就会终止当前进程的执行,并在spanner的日志文件error.log中打印相关的问题,以及问题的调用栈信息。
线上生成的调用栈只有函数地址,没有符号信息,可以将生成的调用栈弄下来