如何得知动态函式库的位置?

提到 Linux 的动态函式库,读者首先会面对到的问题应该是,当我们执行程式时,系统会到哪些目录去搜寻执行档所用到的函式库呢? 其实假如我们去检视 ”/etc/ld.so.conf” 档案中的内容如下:

/usr/X11R6/lib

            /usr/i486-linux-libc5/lib

这里面所存放的是在 Linux 中搜寻动态函式库时的路径资讯,但是这并不是系统所会搜寻的任何路径,以笔者的 RedHat 6.1 来说,我的程式用到了 libreadline.so.3 这个动态函式库,可是笔者把这个函式库移除了,所以实际上,他并不存在这台电脑中,当我启动有用到 libreadline.so.3 的执行档时,系统会先去检视这个函式库是否在动态函式库的快取(档名为 ld.so.cache,在本文稍後会提到)中存在,假如不存在的话,系统仍会试著去找寻这个动态函式库的档案,他所搜寻的路径如下顺序:

/lib/i686/mmx/libreadline.so.3

            /lib/i686/libreadline.so.3

            /lib/mmx/libreadline.so.3

            /lib/libreadline.so.3

            /usr/lib/i686/mmx/libreadline.so.3

            /usr/lib/i686/libreadline.so.3

            /usr/lib/mmx/libreadline.so.3

            /usr/lib/libreadline.so.3

假如还是很难找到的话,就会显示如下的错误讯息:

[root@hlchoua bin]#./test

            test: error in loading shared libraries:

            libreadline.so.3: cannot open shared object file:

            No such file or directory

假如先不透过 ldconfig 把函式库路径设定档 ld.so.conf 的内容处理过,直接把 libreadline.so.3 放到系统内定会去搜寻的目录中的其中一个,例如/usr/lib,然後再追踪一次系统搜寻函式库的过程,系统还是会依循:

/lib/i686/mmx/libreadline.so.3

            /lib/i686/libreadline.so.3

            /lib/mmx/libreadline.so.3

            /lib/libreadline.so.3

            /usr/lib/i686/mmx/libreadline.so.3

            /usr/lib/i686/libreadline.so.3

            /usr/lib/mmx/libreadline.so.3

            /usr/lib/libreadline.so.3

的顺序来寻找 libreadline.so.3 这个动态函式库,但是,在搜寻到最後一个目录後,终於找到了 libreadline.so.3,也使得笔者用来测试的这苹用到动态函式库 libreadline.so.3 的执行档能够顺利的执行。

其实,这种逐一目录寻找的方式很缺乏效率,因此 Linux 提供了一个动态函式库快取的机制,他所存在的档案位置为 /etc/ld.so.cache,举我们之前的例子来说,在ld.so.conf 里面纪录了系统搜寻动态函式库时所会依序去寻找的路径,假如把我们所要加入的动态函式库档案所存在的路径加入此处,或是以下路径的其中之一,这样我们执行程式时,便能够缩短函式库搜寻所花的时间:

/lib/

            /usr/lib/

其实笔者原本是把 libreadline.so.3 放到路径 /usr/lib/mmx,可是我发现在执行 ldconfig 时,他预设并不会主动到 /usr/lib/mmx目录中去取得其中动态函式库档案的资讯,每当我在执行有用到 libreadline.so.3的程式时,他仍然无法透过动态函式库快取取得 libreadline.so.3的路径资讯,而是用一个一个目录尝试开启的方法,直到在 /usr/lib/mmx目录中找到了 libreadline.so.3,因此笔者比较建议假如要新增动态函式库到Linux 中最好是直接新增到 /lib 或是 /usr/lib 目录下,不然就是把函式库所在的目录放到ld.so.conf 里面,再透过 ldconfig 建立动态函式库的快取资料档,这样 Linux 在执行时会更加的便利。

文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!