浅析 Linux LD_LIBRARY_PATH

㈠ 历史背景

现如今、软件大多自带共享库、或者出于安全、或者基于商业考量

如:

Oracle :$ORACLE_HOME/lib

MySQL :$HOME/mysql/lib

下面贴上oracle用户下.bash_profile里关于LD_LIBRARY_PATH设置

export LD_LIBRARY_PATH=$ORACLE_HOME/lib
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/lib:/usr/X11R6/lib
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME/jdk/jre/lib/i386
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME/jdk/jre/lib/i386/server
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$ORACLE_HOME/rdbms/lib 

 ㈡ 几个概念

① 下面几个大意相近

共享库、动态链接库、.so文件

② ld.so 花名又叫:共享库加载器

㈢ 存在的意义

用来告诉 ld.so 到哪里可以找到某某人的共享库

㈣ 大概说说

.so文件的管理和加载由ld.so负责、他在标准路径/lib 或 /usr/lib 里查找APP所需的.so、

但对于非标路径:

Linux做法是把私有路径加入/etc/ld.so.conf、运行ldconfig生成ld.so.cache、ld.so会去查找这个cache

UNIX作风则是采用LD_LIBRARY_PATH来处理非标路径的.so文件

查找优先级如下(Linux):

① LD_LIBRARY_PATH 环境变量指定目录

② /etc/ld.so.conf指定目录

③ 标准路径 先/usr/lib 再 /lib

㈤ 常见错误

error while loading shared libraries:ooxx.so.0:cannot open shared object file:No such file or directory

这里的ooxx是如何命名的、有兴趣的朋友自行参考 点击打开链接

㈥ 通用的方案

① 将这些自带库cp到/usr/lib或/lib、然后ldconfig  有个案例:点击打开链接

② /etc/ld.so.conf 、然后ldconfig

③ LD_LIBRARY_PATH(这个变量有些遭人诟病)

补充:

查看某程序所依赖的共享库的方法如下:

[root@cdio ~]# ldd /home/mysql/mysql/bin/mysqldump
        libpthread.so.0 => /lib64/libpthread.so.0 (0x000000337d200000)
        libz.so.1 => /usr/lib64/libz.so.1 (0x000000337e600000)
        librt.so.1 => /lib64/librt.so.1 (0x000000337d600000)
        libdl.so.2 => /lib64/libdl.so.2 (0x000000337c600000)
        libstdc++.so.6 => /usr/lib64/libstdc++.so.6 (0x00000031ebe00000)
        libm.so.6 => /lib64/libm.so.6 (0x000000337da00000)
        libgcc_s.so.1 => /lib64/libgcc_s.so.1 (0x00000031e9e00000)
        libc.so.6 => /lib64/libc.so.6 (0x000000337c200000)
        /lib64/ld-linux-x86-64.so.2 (0x000000337be00000)

输出可分三列解释:

第一列:程序所依赖的库

第二列:系统提供的与程序所需的库的对应库

第三列:库加载的开始地址

推荐阅读:

相关推荐