引用
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 命令时出现错误:

#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

设置 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.

库依赖的问题,使用 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

问题一目了然:

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 (转载)的更多相关文章

  1. Crystal Clear Applied: The Seven Properties of Running an Agile Project (转载)

    作者Alistair Cockburn, Crystal Clear的7个成功要素,写得挺好. 敏捷方法的关注点,大家可以参考,太激动所以转载了. 原文:http://www.informit.com ...

  2. RTP与RTCP协议介绍(转载)

    RTSP发起/终结流媒体.RTP传输流媒体数据 .RTCP对RTP进行控制,同步.RTP中没有连接的概念,本身并不能为按序传输数据包提供可靠的保证,也不提供流量控制和拥塞控制,这些都由RTCP来负责完 ...

  3. 《Walking the callstack(转载)》

    本文转载自:https://www.codeproject.com/articles/11132/walking-the-callstack Download demo project with so ...

  4. [转载]MVVM模式原理分析及实践

    没有找到很好的MVVM模式介绍文章,简单找了一篇,分享一下.MVVM实现了UI\UE设计师(Expression Blend 4设计界面)和软件工程师的合理分工,在SilverLight.WPF.Wi ...

  5. [转载]:STM32为什么必须先配置时钟再配置GPIO

    转载来源 :http://blog.csdn.net/fushiqianxun/article/details/7926442 [原创]:我来添两句,就是很多同学(包括我)之前搞低端单片机,到了stm ...

  6. [转载]从MyEclipse到IntelliJ IDEA-让你摆脱鼠标,全键盘操作

    从MyEclipse转战到IntelliJ IDEA的经历 注转载址:http://blog.csdn.net/luoweifu/article/details/13985835 我一个朋友写了一篇“ ...

  7. TCP同步与异步,长连接与短连接【转载】

    原文地址:TCP同步与异步,长连接与短连接作者:1984346023 [转载说明:http://zjj1211.blog.51cto.com/1812544/373896   这是今天看到的一篇讲到T ...

  8. 在CentOS 7/6.5/6.4 中安装Java JDK 8(转载)

    转载在CentOS 7/6.5/6.4 中安装Java JDK 8 首先,在你的服务器上运行一下更新. yum update 然后,在您的系统上搜索,任何版本的已安装的JDK组件. rpm -qa | ...

  9. 用C#实现MD5的加密(转载)

    方法一 首先,先简单介绍一下MD5 MD5的全称是message-digest algorithm 5(信息-摘要算法,在90年代初由mit laboratory for computer scien ...

随机推荐

  1. 遍历GridView

    ].Text+"--------------");                }            }

  2. Facebook、新浪微博、Twitter、腾讯微博分享代码

    最近总结一下用到的分享代码 FaceBook分享 <a href="https://www.facebook.com/sharer/sharer.php?u=你的链接" ta ...

  3. java获取当前路径的几种方法

    1.利用System.getProperty()函数获取当前路径: System.out.println(System.getProperty("user.dir"));//use ...

  4. Java并发编程:Thread类的使用介绍

    在学习Thread类之前,先介绍与线程相关知识:线程的几种状态.上下文切换,然后接着介绍Thread类中的方法的具体使用. 以下是本文的目录大纲: 一.线程的状态 二.上下文切换 三.Thread类中 ...

  5. IdeasToComeTrue

    灵感这玩意,果真是有的吧.不考虑什么架构和盈利模式,就只是想到的有趣,随便写写,以飨流年. 我的头脑风暴:爱玩儿aiWaner 2015/08/22 换书: 每个人可能有很多闲置图书,自己看完了觉得好 ...

  6. [vc]如何对radio按钮分组

    如何使用多组? 多组和一组是一样的使用,只要搞清楚哪个是哪一组的就行了.再为对话框添加Radio3和Radio4.很简单,先为这些RadioButton排个顺序,就是排列他们的TABORDER.在对话 ...

  7. MapReuce 编程总结-多MapReduce执行

    学习hadoop,必不可少的就是写MapReduce程序,当然,对于简单的分析程序,我们只需一个MapReduce就能搞定,这里就不提单MapReuce的情况了,网上例子很多,大家可以百度Google ...

  8. 中国 省会 地级市 经纬度 city array

    <?php $city_arr = array ( '北京' => array ( 'gis_lng' => '116.405285', 'gis_lat' => '39.90 ...

  9. Python的maketrans() 方法

    描述 Python maketrans() 方法用于创建字符映射的转换表,对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标. 注:两个字符 ...

  10. 算法面试题 之 最长递增子序列 LIS

    找出最长递增序列 O(NlogN)(不一定连续!) 参考 http://www.felix021.com/blog/read.php?1587%E5%8F%AF%E6%98%AF%E8%BF%9E%E ...