关于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
原文引述一下memcached的问题:
LD_DEBUG 是 glibc
中的 loader 为了方便自身调试而设置的一个环境变量。通过设置这个环境变量,可以方便的看到 loader 的加载过程。 以在 64位 centos
上编译安装 memcached 为例,安装阶段顺利,执行 memcached 命令时出现错误:
/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
变量获得更多信息:
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 参数:
–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
问题一目了然:
参考原文:
http://grepk.com/?p=62
http://blog.chinaunix.net/u1/59481/showart_2131371.html
关于LD_DEBUG (转载)的更多相关文章
- Crystal Clear Applied: The Seven Properties of Running an Agile Project (转载)
作者Alistair Cockburn, Crystal Clear的7个成功要素,写得挺好. 敏捷方法的关注点,大家可以参考,太激动所以转载了. 原文:http://www.informit.com ...
- RTP与RTCP协议介绍(转载)
RTSP发起/终结流媒体.RTP传输流媒体数据 .RTCP对RTP进行控制,同步.RTP中没有连接的概念,本身并不能为按序传输数据包提供可靠的保证,也不提供流量控制和拥塞控制,这些都由RTCP来负责完 ...
- 《Walking the callstack(转载)》
本文转载自:https://www.codeproject.com/articles/11132/walking-the-callstack Download demo project with so ...
- [转载]MVVM模式原理分析及实践
没有找到很好的MVVM模式介绍文章,简单找了一篇,分享一下.MVVM实现了UI\UE设计师(Expression Blend 4设计界面)和软件工程师的合理分工,在SilverLight.WPF.Wi ...
- [转载]:STM32为什么必须先配置时钟再配置GPIO
转载来源 :http://blog.csdn.net/fushiqianxun/article/details/7926442 [原创]:我来添两句,就是很多同学(包括我)之前搞低端单片机,到了stm ...
- [转载]从MyEclipse到IntelliJ IDEA-让你摆脱鼠标,全键盘操作
从MyEclipse转战到IntelliJ IDEA的经历 注转载址:http://blog.csdn.net/luoweifu/article/details/13985835 我一个朋友写了一篇“ ...
- TCP同步与异步,长连接与短连接【转载】
原文地址:TCP同步与异步,长连接与短连接作者:1984346023 [转载说明:http://zjj1211.blog.51cto.com/1812544/373896 这是今天看到的一篇讲到T ...
- 在CentOS 7/6.5/6.4 中安装Java JDK 8(转载)
转载在CentOS 7/6.5/6.4 中安装Java JDK 8 首先,在你的服务器上运行一下更新. yum update 然后,在您的系统上搜索,任何版本的已安装的JDK组件. rpm -qa | ...
- 用C#实现MD5的加密(转载)
方法一 首先,先简单介绍一下MD5 MD5的全称是message-digest algorithm 5(信息-摘要算法,在90年代初由mit laboratory for computer scien ...
随机推荐
- BFC / hasLayout
BFC - block formatting context 1.float的值不能为none 2.overflow的值不能为visible 3.display的值为table-cell,table- ...
- 利用jquery写的一个TAB页切换效果
函数如下 /** *切换效果 */ function switab(tab,con,tab_c_css,tab_n_css,no) { $(tab).each(function(i){ if(i == ...
- 使用分析函数实现Oracle 10G提供的CONNECT_BY_ISLEAF和CONNECT_BY_ROOT的功能(转载)
文章转载至:http://blog.csdn.net/wzy0623/article/details/1644049 如果,有侵犯您权益的地方,烦请及时的告知我,我会即刻停止侵权行为 Oracle 1 ...
- poj2987 Firing
以前只是A过很简单的最大闭合权像hdu1565之类,完全的最大流模板题.但是都完全不太懂最大闭合权的定义及其用途. 关于最大流的基础知识,大家可以自己网上搜索关键字.有点基础的哥们妹们,推荐看看胡伯涛 ...
- C/C++中使用的正则表达式库
正则表达式 正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符.及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑. 正则引擎主要可以分 ...
- clip原理
1.clip的概述: clip是修剪之意 clip有4个属性值:inherit auto rect(20px,40px,60px,0px) !important 其中有作用的仅rect这个属性值,着重 ...
- Python 错误和异常
1.Python异常类 Python是面向对象语言,所以程序抛出的异常也是类.常见的Python异常有以下几个,大家只要大致扫一眼,有个映像,等到编程的时候,相信大家肯定会不只一次跟他们照面(除非你不 ...
- jQuery 插件入门
先看http://www.cnblogs.com/lideng/p/3605551.html http://www.cnblogs.com/xcj26/p/3345556.html (非常细致 很多 ...
- windows理论基础(一)
windows体系结构 一. 用户模式和内核模式 (user mode &kernel mode) Intel x86 处理器的体系结构定义了四种特权级,或特为四个环.来保护系统代码不会被低 ...
- VS2010/MFC对话框:一般属性页对话框的创建及显示
一般属性页对话框的创建及显示 本节将介绍一般属性页对话框的创建和显示. 实际上,一般属性页对话框的创建和显示过程和向导对话框是很类似的.鸡啄米将上一节中的向导对话框进行少量修改,使其成为一般属性页对话 ...