关于LD_DEBUG
来源:互联网 发布:手机视频通话软件 编辑:程序博客网 时间:2024/05/16 16:12
引用
LD_DEBUG
The dynamic library loader used in linux (part of glibc) has some neat tricks. One of these is that you can set an environment variable called
LD_DEBUG
to show how symbols (variables and functions, for example) are resolved for a dynamic executable. This can sometimes help resolve obscure bugs where your application isn’t doing what you expect (assuming it is caused by symbols being resolved differently to what you were expecting).
This is very useful if you get segmentation violations or aborts for a program - this can sometimes be caused by linking against the wrong version of a library. This is also a really good way to understand what happens when you run any program! It has some self-documentation - for the impatient, you can do
The dynamic library loader used in linux (part of glibc) has some neat tricks. One of these is that you can set an environment variable called
LD_DEBUG
to show how symbols (variables and functions, for example) are resolved for a dynamic executable. This can sometimes help resolve obscure bugs where your application isn’t doing what you expect (assuming it is caused by symbols being resolved differently to what you were expecting).
This is very useful if you get segmentation violations or aborts for a program - this can sometimes be caused by linking against the wrong version of a library. This is also a really good way to understand what happens when you run any program! It has some self-documentation - for the impatient, you can do
原文引述一下memcached的问题:
LD_DEBUG 是 glibc 中的 loader 为了方便自身调试而设置的一个环境变量。通过设置这个环境变量,可以方便的看到 loader 的加载过程。 以在 64位 centos 上编译安装 memcached 为例,安装阶段顺利,执行 memcached 命令时出现错误:
#memcached –h
/usr/local/memcached/bin/memcached: error while loading shared libraries: libevent-1.4.so.2:
cannot open shared object file: No such file or directory
#find / -name libevent-1.4.so.2
/usr/lib/libevent-1.4.so.2
/usr/local/memcached/bin/memcached: error while loading shared libraries: libevent-1.4.so.2:
cannot open shared object file: No such file or directory
#find / -name libevent-1.4.so.2
/usr/lib/libevent-1.4.so.2
设置 LD_DEBUG 变量获得更多信息:
#LD_DEBUG=help ls
Valid options for the LD_DEBUG environment variable are:
libs display library search paths
reloc display relocation processing
files display progress for input file
symbols display symbol table processing
bindings display information about symbol binding
versions display version dependencies
all all previous options combined
statistics display relocation statistics
unused determined unused DSOs
help display this help message and exit
To direct the debugging output into a file instead of standard output
a filename can be specified using the LD_DEBUG_OUTPUT environment variable.
Valid options for the LD_DEBUG environment variable are:
libs display library search paths
reloc display relocation processing
files display progress for input file
symbols display symbol table processing
bindings display information about symbol binding
versions display version dependencies
all all previous options combined
statistics display relocation statistics
unused determined unused DSOs
help display this help message and exit
To direct the debugging output into a file instead of standard output
a filename can be specified using the LD_DEBUG_OUTPUT environment variable.
库依赖的问题,使用 libs 参数:
#LD_DEBUG=libs /usr/local/memcached/bin/memcached –h
9808: find library=libevent-1.4.so.2 [0]; searching
9808: search cache=/etc/ld.so.cache
9808: search path=/lib64/tls/x86_64:/lib64/tls:/lib64/x86_64:/lib64:/usr/lib64/tls/x86_64
/usr/lib64/tls:/usr/lib64/x86_64:/usr/lib64
(system search path)
9808: trying file=/lib64/tls/x86_64/libevent-1.4.so.2
9808: trying file=/lib64/tls/libevent-1.4.so.2
9808: trying file=/lib64/x86_64/libevent-1.4.so.2
9808: trying file=/lib64/libevent-1.4.so.2
9808: trying file=/usr/lib64/tls/x86_64/libevent-1.4.so.2
9808: trying file=/usr/lib64/tls/libevent-1.4.so.2
9808: trying file=/usr/lib64/x86_64/libevent-1.4.so.2
9808: trying file=/usr/lib64/libevent-1.4.so.2
9808: /usr/local/memcached/bin/memcached: error while loading shared libraries: libevent-1.4.so.2: cannot open shared object file: No such file or directory
9808: find library=libevent-1.4.so.2 [0]; searching
9808: search cache=/etc/ld.so.cache
9808: search path=/lib64/tls/x86_64:/lib64/tls:/lib64/x86_64:/lib64:/usr/lib64/tls/x86_64
/usr/lib64/tls:/usr/lib64/x86_64:/usr/lib64
(system search path)
9808: trying file=/lib64/tls/x86_64/libevent-1.4.so.2
9808: trying file=/lib64/tls/libevent-1.4.so.2
9808: trying file=/lib64/x86_64/libevent-1.4.so.2
9808: trying file=/lib64/libevent-1.4.so.2
9808: trying file=/usr/lib64/tls/x86_64/libevent-1.4.so.2
9808: trying file=/usr/lib64/tls/libevent-1.4.so.2
9808: trying file=/usr/lib64/x86_64/libevent-1.4.so.2
9808: trying file=/usr/lib64/libevent-1.4.so.2
9808: /usr/local/memcached/bin/memcached: error while loading shared libraries: libevent-1.4.so.2: cannot open shared object file: No such file or directory
问题一目了然:
ln -s /usr/lib/libevent-1.4.so.2 /usr/lib64/libevent-1.4.so.2
参考原文:
http://grepk.com/?p=62
http://blog.chinaunix.net/u1/59481/showart_2131371.html
- 关于LD_DEBUG
- 关于LD_DEBUG
- 关于LD_DEBUG
- LD_DEBUG 命令
- 使用 LD_DEBUG
- ld_preload && ld_debug
- LD_DEBUG使用
- LD_DEBUG=xxx
- ldconfig及 LD_LIBRARY_PATH,LD_DEBUG ,LD_PRELOAD
- linux上使用LD_DEBUG环境变量查看程序使用哪些库
- 关于
- 关于
- 关于++,--
- 关于#
- 关于。。。
- 关于
- 关于......
- 关于
- reactor与proactor的概念
- python27 IDLE 自动提示功能
- 高性能I/O设计模式Reactor和Proactor
- 如何配置Eclipse+Jdk+Tomcat+Myeclipse
- android获取ip地址Android4.0
- 关于LD_DEBUG
- LeetCode - Binary Tree Zigzag Level Order Traversal
- ubuntu 目录结构
- ACCESS中的Update语句不支持Select的解决办法
- reactor/proactor模型简介
- php与jquery开发注意事项
- hdu1125--附上多个最短路方法代码
- Java中间件JMS(一)之ActiveMQ入门
- wikioi p1160 蛇形矩阵