关于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 ...
随机推荐
- javaScript 工作必知(五) eval 的使用
eval eval(parse) parse :里面跟参数字符串,我们知道执行javascript 会编译执行, 改变全局变量的值: var x = 2; //定义的全局变量 alert(x); ...
- 数据库值N'string'
加上 N 代表存入数据库时以 Unicode 格式存储.N'string' 表示string是个Unicode字符串 Unicode 字符串的格式与普通字符串相似,但它前面有一个 N 标识符(N 代表 ...
- 指定hive输出格式
0.11版本以前: sed -e 's/\x01/|/g' file 0.11版本以后: insert overwrite local directory '/opt/aimcpro/libc/tes ...
- apache-tomcat-7 设置最大上传.war文件大小[zhuan]
在利用tomcat自带的主机管理页面进行WAR包部署的时候,提示文件太大,无法上传. 解决方案: 找到 /usr/local/apache-tomcat7/webapps/manager/WEB- ...
- 整理部分JS 控件 WEB前端常用的做成Jsp项目,方便今后直接用
整理部分JS 控件 WEB前端常用的做成Jsp项目,方便今后直接用 最近又没时间了,等用时间了,再加入更多的, 源码下载: http://download.csdn.net/detail/liang ...
- break的使用例一
/* Name:break的使用例一 Copyright: By.不懂网络 Author: Yangbin Date:2014年2月21日 02:28:24 Description:本程序代码无如何含 ...
- C语言复合梯形公式实现定积分
假设被积函数为 f x ,积分区间为 , a b ,把区间 , a b 等分成 n 个小区间, 各个区间的长度为 h ,即 / h b a n ,称之为“步长” ...
- nyoj 21三个水杯(BFS + 栈)
题目链接: http://acm.nyist.net/JudgeOnline/problem.php?pid=21 思想: 看了一下搜索就来写了这题(BFS 找出最短路径 所以用此来进行搜索) 这题在 ...
- MySQL Mysqlslap
在mysql5.1以后的版本:客户端带了个工具mysqlslap可以对mysql进行压力测试: 可以使用mysqlslap --help来显示使用方法: Default options are rea ...
- [置顶] What is the difference between Category and Class Extension?
细心的人会发现当我们new 一个文件的时候会发现下图的部分. 但是这个问题来了Category 和 Extension 就近又什么区别呢? 1:什么是Category? 实现这样一种场景,当我们用我们 ...