zoukankan      html  css  js  c++  java
  • 关于LD_DEBUG (转载)

    引用
    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

  • 相关阅读:
    [编译器] GCC编译过程 [ISO > ESc]
    《计算机网络 4》 应用层
    [编译器] cc、gcc、g++、CC的区别概括
    这个VS2010 技巧 折磨了我好久。留个贴纪念下。
    C#设置系统日期和时间的代码
    C# string格式的日期时间字符串转为DateTime类型
    中文普通图书著者号码的取号规定
    汉语著者号自动生成系统的设计与实现
    网络环境下提高图书编目工作效率搞高的方法
    jquery 超级select 插件 selectsearch v3.0.0.0插件 支持汉字、拼音、英文快速定位查询的超级select插件。可方向键、tab 键快速选择。
  • 原文地址:https://www.cnblogs.com/diyunpeng/p/3663201.html
Copyright © 2011-2022 走看看