博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
关于LD_DEBUG (转载)
阅读量:7132 次
发布时间:2019-06-28

本文共 2716 字,大约阅读时间需要 9 分钟。

引用
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://ykcrl.baihongyu.com/

你可能感兴趣的文章
Python3 编码hexstring到ascii详解
查看>>
当<script>中的type等于text/html时,我们可以做很多事件!
查看>>
我是一只IT小小鸟读后感
查看>>
Linux 内核内存池
查看>>
Mybatis与Spring的mapper代理整合方法
查看>>
iOS11 仿大标题 导航栏
查看>>
LinuxUnix time时间戳的处理转换函数
查看>>
全参考视频质量评价方法(PSNR,SSIM)以及与MOS转换模型
查看>>
Spring
查看>>
微信小程序如何发送短信验证码,无需搭建服务器
查看>>
freemarker2 指令
查看>>
开学第一课·
查看>>
Mysql重复数据查询置为空
查看>>
(转)tomcat7.0 manager app和host manager web管理
查看>>
20165232 第三周总结
查看>>
计算机组成原理-第3章-3.2
查看>>
黄聪:发送键盘指令System.Windows.Forms.SendKeys.Send
查看>>
前端面试题二十五
查看>>
Robot Framework自动化测试(一)---搭建环境
查看>>
JavaScript、Python、java、Go算法系列之【快速排序】篇
查看>>