用户工具

站点工具


docs:compile:so

so文件 Shared Object

ldconfig命令

ldconfig命令的用途主要是在默认搜寻目录/lib/usr/lib以及动态库配置文件/etc/ld.so.conf内所列的目录下,搜索出可共享的动态链接库(格式如lib*.so*),进而创建出动态装入程序(ld.so)所需的连接和缓存文件。缓存文件默认为/etc/ld.so.cache,此文件保存已排好序的动态链接库名字列表,为了让动态链接库为系统所共享,需运行动态链接库的管理命令ldconfig,此执行程序存放在/sbin目录下。

ldconfig通常在系统启动时运行,而当用户安装了一个新的动态链接库时,就需要再次手工运行这个命令刷新状态。

command usage


[root@centos76 structure_modules]# ldconfig --help
Usage: ldconfig [OPTION...]
Configure Dynamic Linker Run Time Bindings.

  -c, --format=FORMAT        Format to use: new, old or compat (default)
  -C CACHE                   Use CACHE as cache file
  -f CONF                    Use CONF as configuration file
  -i, --ignore-aux-cache     Ignore auxiliary cache file
  -l                         Manually link individual libraries.
  -n                         Only process directories specified on the command
                             line.  Don't build cache.
  -N                         Don't build cache
  -p, --print-cache          Print cache
  -r ROOT                    Change to and use ROOT as root directory
  -v, --verbose              Generate verbose messages
  -X                         Don't generate links
  -?, --help                 Give this help list
      --usage                Give a short usage message
  -V, --version              Print program version

Mandatory or optional arguments to long options are also mandatory or optional
for any corresponding short options.

For bug reporting instructions, please see:
<http://www.gnu.org/software/libc/bugs.html>


ldconfig [-v|--verbose] [-n] [-N] [-X] [-f CONF] [-C CACHE] [-r ROOT] [-l] [-p|--print-cache] [-c FORMAT] [--format=FORMAT] [-V] [-?|--help|--usage] path... 

默认配置文件/etc/ld.so.conf加载/etc/ld.so.conf.d/*.conf
-v或--verbose:用此选项时,ldconfig将显示正在扫描的目录及搜索到的动态链接库,还有它所创建的连接的名字。
-n:用此选项时,ldconfig仅扫描命令行指定的目录,不扫描默认目录(/lib、/usr/lib),也不扫描配置文件/etc/ld.so.conf所列的目录。
-N:此选项指示ldconfig不重建缓存文件(/etc/ld.so.cache),若未用-X选项,ldconfig照常更新文件的连接。
-X:此选项指示ldconfig不更新文件的连接,若未用-N选项,则缓存文件正常更新。
-f CONF:此选项指定动态链接库的配置文件为CONF,系统默认为/etc/ld.so.conf。
-C CACHE:此选项指定生成的缓存文件为CACHE,系统默认的是/etc/ld.so.cache,此文件存放已排好序的可共享的动态链接库的列表。
-r ROOT:此选项改变应用程序的根目录为ROOT(是调用chroot函数实现的)。选择此项时,系统默认的配置文件/etc/ld.so.conf,实际对应的为ROOT/etc/ld.so.conf。如用-r /usr/zzz时,打开配置文件/etc/ld.so.conf时,实际打开的是/usr/zzz/etc/ld.so.conf文件。用此选项,可以大大增加动态链接库管理的灵活性。
-l:通常情况下,ldconfig搜索动态链接库时将自动建立动态链接库的连接,选择此项时,将进入专家模式,需要手工设置连接,一般用户不用此项。
-p或--print-cache:此选项指示ldconfig打印出当前缓存文件所保存的所有共享库的名字。
-c FORMAT 或 --format=FORMAT:此选项用于指定缓存文件所使用的格式,共有三种:old(老格式),new(新格式)和compat(兼容格式,此为默认格式)。
-V:此选项打印出ldconfig的版本信息,而后退出。
-? 或 --help 或 --usage:这三个选项作用相同,都是让ldconfig打印出其帮助信息,而后退出。

使用 ldconfig几个需要注意的地方:

  1. 往/lib和/usr/lib里面加东西,是不用修改/etc/ld.so.conf的,但是完了之后要调一下ldconfig,不然这个library会找不到。
  2. 想往上面两个目录以外加东西的时候,一定要修改/etc/ld.so.conf,然后再调用ldconfig,不然也会找不到。
  3. 比如安装了一个mysql到/usr/local/mysql,mysql有一大堆library在/usr/local/mysql/lib下面,这时就需要在/etc/ld.so.conf下面加一行/usr/local/mysql/lib,保存过后ldconfig一下,新的library才能在程序运行时被找到。
  4. 如果想在这两个目录以外放lib,但是又不想在/etc/ld.so.conf中加东西(或者是没有权限加东西)。那也可以,就是export一个全局变量LD_LIBRARY_PATH,如export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/mysql/lib,然后运行程序的时候就会去这个目录中找library。一般来讲这只是一种临时的解决方案,在没有权限或临时需要的时候使用。
  5. ldconfig做的这些东西都与运行程序时有关,跟编译时一点关系都没有。编译的时候还是该加-L就得加,不要混淆了。
  6. 总之,就是不管做了什么关于library的变动后,最好都ldconfig一下,不然会出现一些意想不到的结果。不会花太多的时间,但是会省很多的事。
  7. 再有,诸如libdb-4.3.so文件头中是会含有库名相关的信息的(即含“libdb-4.3.so”,可用strings命令察看),因此仅通过修改文件名以冒充某已被识别的库(如libdb-4.8.so)是行不通的。为此可在编译库的Makefile中直接修改配置信息,指定特别的库名。

    echo "/usr/local/lib"  >> /etc/ld.so.conf.d/local.conf
    ldconfig
    

使用示例

[centos]$ /usr/local/src/nginx-1.8.0] /usr/local/nginx/sbin/nginx -t
/usr/local/nginx/sbin/nginx: error while loading shared libraries: libpcre.so.1: cannot open shared object file: No such file or directory

以上报错解决方案

#未定位于pcre libraries
find / -type f -name 'libpcre.so*'

[centos]$ find / -name 'libpcre.so*'
/usr/local/src/pcre-8.31/.libs/libpcre.so.1
/usr/local/src/pcre-8.31/.libs/libpcre.so
/usr/local/src/pcre-8.31/.libs/libpcre.so.1.0.1
/usr/local/lib/libpcre.so.1
/usr/local/lib/libpcre.so
/usr/local/lib/libpcre.so.1.0.1
/lib64/libpcre.so.0.0.1
/lib64/libpcre.so.0

[centos]$ vim /etc/ld.so.conf
include ld.so.conf.d/*.conf
/usr/local/lib # 增加这行

ldconfig #重载配置文件

ldd

作用:用来查看程序运行所需的共享库,常用来解决程序因缺少某个库文件而不能运行的一些问题。

ldd命令原理

1、首先ldd不是一个可执行程序,而只是一个shell脚本;

2、ldd能够显示可执行模块的dependency,其原理是通过设置一系列的环境变量,如:LD_TRACE_LOADED_OBJECTS、LD_WARN、LD_BIND_NOW、LD_LIBRARY_VERSION、LD_VERBOSE等。当LD_TRACE_LOADED_OBJECTS环境变量不为空时,任何可执行程序在运行时,它都会只显示模块的dependency,而程序并不真正执行。可以在shell终端测试一下: (1) export LD_TRACE_LOADED_OBJECTS=1

(2) 再执行任何的程序,如ls等,看看程序的运行结果

3、ldd显示可执行模块的dependency的工作原理,其实质是通过ld-linux.so(elf动态库的装载器)来实现的。我们知道,ld-linux.so模块会先于executable模块程序工作,并获得控制权,因此当上述的那些环境变量被设置时,ld-linux.so选择了显示可执行模块的dependency。

4、实际上可以直接执行ld-linux.so模块,如:/lib/ld-linux.so.2 –list program(这相当于ldd program)。

比如:

export LD_TRACE_LOADED_OBJECTS
#无效。

#而
 [centos]$  export LD_TRACE_LOADED_OBJECTS=
#或
 [centos]$  export LD_TRACE_LOADED_OBJECTS=1
#或
 [centos]$  export LD_TRACE_LOADED_OBJECTS=0
#均可使其生效,运行ls命令显示如下:

#复制代码
 [centos]$  ls
    linux-gate.so.1 =>  (0xb77b2000)
    libselinux.so.1 => /lib/i386-linux-gnu/libselinux.so.1 (0xb777a000)
    librt.so.1 => /lib/i386-linux-gnu/librt.so.1 (0xb7771000)
    libacl.so.1 => /lib/i386-linux-gnu/libacl.so.1 (0xb7767000)
    libc.so.6 => /lib/i386-linux-gnu/libc.so.6 (0xb75bd000)
    libdl.so.2 => /lib/i386-linux-gnu/libdl.so.2 (0xb75b8000)
    /lib/ld-linux.so.2 (0xb77b3000)
    libpthread.so.0 => /lib/i386-linux-gnu/libpthread.so.0 (0xb759d000)
    libattr.so.1 => /lib/i386-linux-gnu/libattr.so.1 (0xb7597000)
复制代码
撤销环境变量:

 [centos]$ unset LD_TRACE_LOADED_OBJECTS
 
3、ldd显示可执行模块的dependency的工作原理,其实质是通过ld-linux.so(elf动态库的装载器)来实现的。开始执行程序后,ld-linux.so模块会先于executable模块程序工作,并获得控制权,因此当上述的那些环境变量被设置时,ld-linux.so选择了显示可执行模块的dependency。

4、实际上可以直接执行ld-linux.so模块,如:/lib/ld-linux.so.2 –list program(相当于ldd program)。

ld

命令编程开发 ld命令是GNU的连接器,将目标文件连接为可执行程序。

docs/compile/so.txt · 最后更改: 2020/09/25 21:49 (modify by Amos)