Error While Loading Shared Libraries, Cannot Open Shared Object File
In the “I wish the Internet had an actual correct answer” category comes a question from a Windows colleague trying to build software on Linux. He asks “I’m trying to do some web performance testing and I compiled weighttp
and the libev libraries, which worked fine, but when I try to run the program it gives me the following error.”
weighttp: error while loading shared libraries: libev.so.4: cannot open shared object file: No such file or directory
“I checked /usr/local/lib and the files are there. Do you have a suggestion?”
Ah yes, a classic problem when building software. The problem here is that libev installed itself into /usr/local/lib:
$ ls-l /usr/local/lib/libev*
-rw-r--r--.1 root root 435770 Feb2215:20/usr/local/lib/libev.a
-rwxr-xr-x.1 root root 926 Feb2215:20/usr/local/lib/libev.la
lrwxrwxrwx.1 root root14 Feb 2215:20/usr/local/lib/libev.so-> libev.so.4.0.0
lrwxrwxrwx.1 root root14 Feb 2215:20/usr/local/lib/libev.so.4-> libev.so.4.0.0
-rwxr-xr-x.1 root root 174059 Feb2215:20/usr/local/lib/libev.so.4.0.0
…but the dynamic linker doesn’t know where they are, because it’s never heard of /usr/local/lib. /usr/local is a traditional place for add-on software to install itself, so it doesn’t interfere with the system libraries.
If you’re coming from a Windows background the .so files are essentially equal to DLLs, and load when you execute a program that depends on them. Programs that use dynamic libraries have several advantages, in that they’re smaller, and the libraries can be
updated without having to recompile all the programs that depend on them. So if there’s a security problem with libev you can just patch libev, and not have to rebuild everything that uses that library.
You can see what libraries a program is dynamically linked to with the ‘ldd’ command:
$ ldd /usr/local/bin/weighttp
linux-vdso.so.1 => (0x00007fff251ff000)
libev.so.4 => not found
libpthread.so.0 => /lib64/libpthread.so.0 (0x00007f8f1cc1e000)
libc.so.6 => /lib64/libc.so.6 (0x00007f8f1c88b000)
/lib64/ld-linux-x86-64.so.2 (0x00007f8f1ce49000)
That confirms we’re just dealing with the new library, and not some other problem. Cool.
Anyhow, there are five fixes that come to mind, and I’ll group them into “terrible ideas” and “decent ideas.” Of course, terrible and decent are my opinion, and your situation may dictate a different conclusion, so I’ll
add some commentary. If you’re looking for the quickest way out skip to #5.
Suboptimal Fixes/Terrible Ideas[0]
1.Install the libraries to /usr/lib instead of /usr/local/lib. I really don’t like this because you’re installing add-on software into a system directory,and you might introduce a conflict, overwrite a pre-existing library,
and/or destabilize other parts of the system. People complain about Windows being unstable, and this sort of thing is exactly why it gets unstable – installers overwrite system DLLs with their own all the time. Recent versions of Windows go to a lot of trouble
to keep installers from doing this. If you’re bored lookup the WinSxS subsystem, which is what Microsoft built to deal with the problem. Linux doesn’t have something that deals with the problem, it just assumes that you know what you’re doing. Such is the
power of UNIX. Here’s a rope, try not to hang yourself.
When you’re building open-source software under a UNIX OS you often use the “configure” command. You can change where the software installs by using the “prefix” flag:
$ ./configure –prefix=/usr
This will also install all the binaries, header files, etc. into the system directories. If you were one of my system administrators I’d get on your case for doing this and make you go back and do it right. This isn’t
the right way. Don’t do it this way. The right ways are simple, do those instead.
2. Make a symbolic link from /lib to the files in /usr/local/lib. This is less intrusive than installing everything to /usr, but still a bad idea, for most of the same reasons as #1.If you’re the kind of person that likes
to smoke while refueling vehicles go ahead and try:
$ sudo ln -s /usr/local/lib/libev.so.4 /usr/lib/libev.so.4
$ sudo ldconfig
Obviously substitute the correct file name for libev.so.4. The ‘ldconfig’ command updates the system’s dynamic library cache so it sees the changed libraries.
Still, don’t do this. Bad sysadmin.
3. Copy the files from/usr/local/lib into /usr/lib. This is even more of a bad idea than #2 because now you’ve got two sets of libraries, and if you ever have to patch or upgrade it you’ll probably forget about one set.
Oops. I hope you weren’t patching because of a security problem!
$ sudo cp /usr/local/lib/libev.* /usr/lib
$ sudo ldconfig
With all these ideas you’re also very likely to run afoul of the 32-bit vs. 64-bit thing with newer OSes, where 32-bit libraries go in /usr/lib and 64-bit libraries go in /usr/lib64. It might work, it might not work,
but the better ways are a heck of a lot simpler.
Better Idea
4. Set the environment variable LD_LIBRARY_PATH to point to /usr/local/lib. If you are new to UNIX/Linux and don’t know what shell you’re running, use the ‘ps’ command to see the processes you’re running:
$ ps
PID TTY TIME CMD
7796 pts/4 00:00:00 tcsh
10048 pts/4 00:00:00 ps
Hey look, I’m running tcsh, so my fix would be:
setenv LD_LIBRARY_PATH /usr/local/lib
and I can put that command into ~/.cshrc so it executes when I log in.
If ps tells you you’re running bash:
$ ps
PID TTY TIME CMD
7796 pts/4 00:00:00 bash
10048 pts/4 00:00:00 ps
the command is:
export LD_LIBRARY_PATH="/usr/local/lib"
and you can put that into your ~/.bashrc so it’s always there.
Changing the environment is a per-user thing, so other users on the system will need to do this, or you’d need to put the fixes in /etc/bashrc or /etc/csh.cshrc, the system-wide login scripts. This fix is nice, though,
if you don’t have root-level privileges on a system, and/or want to install things into your own home directory.
Absolutely Simple, Best FixEver[2]
5. If you have root privileges on this Linux box, why not just ask the dynamic linker to check /usr/local/lib, too? Edit the file /etc/ld.so.conf and add “/usr/local/lib” on its own line at the bottom[3]. DO NOT REMOVE
THINGS FROM THIS FILE. When you’re done it might look something like:
$ cat /etc/ld.so.conf
include ld.so.conf.d/*.conf
/usr/local/lib
or it might look completely different, with the exception of the last line. Run ldconfig to tell it to update the cache:
$ sudo ldconfig
You can check your work with:
$ ldconfig -p | grep local
You should see the stuff in/usr/local/lib show up now, and your binary works. Boy, that was easy, and you didn’t make more work for yourself down the road, destabilize the system, overwrite system files, or leave security
vulnerabilities lying around. Cool.
Good luck. As always, if you see a problem here let me know in the comments. If you have other questions you’d like me to answer in a blog post you should email them or tweet them at me! Mycontact information is on the
top-right at lonesysadmin.net. While you’re there why don’t you subscribe to my feed, too?
———
[0] So why did I list the bad ideas? Because you’ll see every one suggested as a fix by people pretending tobe experts[1]. It is my hope that you’ll understand why these are bad ideas,why they might cause you more work
in the long run, and can make an informeddecision.
[1] I am not an expert, I’m a guy that’s done a lot of this stuff, and might be able to answer your question. If someone calls themselves an expert run away.
[2] Not guaranteed to be simple or best. I like it, though.
[3] If you’re stymied by editing on the command line try “nano.” It’s a simple editor and is often installed. Another option is ‘vi’ but it’s cryptic, and you can use Google to find a tutorial on it if you need one. The
nice thing about vi is that it’s always installed.
https://lonesysadmin.net/2013/02/22/error-while-loading-shared-libraries-cannot-open-shared-object-file/
Error While Loading Shared Libraries, Cannot Open Shared Object File的更多相关文章
- 解决 Linux error while loading shared libraries: cannot open shared object file: No such file or directory
安装最新版本Emqtt,参照官方文档安装后,执行报错: Linux error while loading shared libraries libsctp.so.1: cannot open sha ...
- [持续交付实践] pipeline使用:Shared Libraries
前言 随着pipeline交付流水线在团队中的推广,使用pipeline脚本的job也迅速增加.虽然我们已经基于公司的技术栈特点做了一个尽可能通用的pipeline脚本样例,让搭建者只需要修改几个赋值 ...
- linux使用wkhtmltopdf报错error while loading shared libraries:
官网提示 linux需要这些动态库.depends on: zlib, fontconfig, freetype, X11 libs (libX11, libXext, libXrender) 在li ...
- python3: error while loading shared libraries: libpython3.5m.so.1.0: cannot open shared object file: No such file or directory
安装python3遇到报错: wget https://www.python.org/ftp/python/3.5.2/Python-3.5.2.tgz ./configure --prefix=/u ...
- error while loading shared libraries: libmysqlclient.so.18: cannot open shared object file: No such file or directory
zabbix3.2启动有如下报错: # service zabbix_server startStarting zabbix_server: /home/zabbix-server/sbin/zab ...
- 错误解决:error while loading shared libraries: libcurl.so.4: cannot open shared object file: No such file or directory
执行以下代码,生成唯一的UID $fp = popen("/xxx/bin/tools/uuidgen system", "r");// $uid = frea ...
- ebs r12 -- adadmin: error while loading shared libraries: libclntsh.so.10.1
安装EBS R12.2增加中文字符集时,运行$AU_TOP/bin/adadmin出错: $ adadmin adadmin: error while loading shared libraries ...
- 【转】error while loading shared libraries: libevent-2.0.so.5: cannot open shared object file: No such file or directory
错误信息: /usr/local/memcacheq/bin/memcacheq: error while loading shared libraries: libevent-2.0.so.5: c ...
- ssh 发现了error while loading shared libraries这种错
在Linux下运行程序时,发现了error while loading shared libraries这种错误,一时间不知道解决办法,在网上搜索,终于解决了: ./tests: error whil ...
随机推荐
- Excel函数学习:HLOOKUP函数
Excel函数学习:HLOOKUP函数 HLOOKUP函数查找表的第一行中的值,返回该表中与找到的值在同一列的另一个值. 什么情况下使用HLOOKUP? HLOOKUP函数可以在查找行中找到精确匹配值 ...
- io.spring.platform继承方式和import方式更改依赖版本号的问题
使用io.spring.platform时,它会管理各类经过集成测试的依赖版本号. 但有的时候,我们想使用指定的版本号,这个时候就需要去覆盖io.spring.platform的版本号. 前面的文章总 ...
- day37 06-Hibernate二级缓存:更新时间戳区
二级缓存区:类缓存区,集合缓存区,更新时间戳区. 它会记录一个时间T1.其实在我们查询之后它会记录一个时间.假设时间叫做T1.就是你查询完之后的当前时间是T1.当我们自己手动在下面做了一个更新之后,它 ...
- Axure之添加点击页面
添加悬停字体变色的效果 页面载入时的频道预设(我做错了,英文版本不知道那个是页面载入时的事件) 我的博客不够完善,看不到全部的图片.我后续会修改我的网站的
- JavaScript 中的多线程通信的方法
在Html 5诞生之后,我们可以使用javascript来实现多线程处理.H5 新增了一个web workers api,使用这个API,用户可以很容易地创建在后台运行的线程,H5 中被称为workd ...
- Ubuntu上更换163源 - Mars Loo的博客
转载*请注明原始出处:http://blog.csdn.net/a464057216/article/details/50865895 先备份源/etc/apt/sources.list为source ...
- 解决WSL上运行plantUML中文乱码问题
生成UML图命令: java -jar plantuml.jar -charset UTF-8 my.txt 1. 保证my.txt 使用uft-8编码 2. wsl中安装中文字体: 如: sudo ...
- Legal or Not HDU - 3342 (拓扑排序)
注意点: 输入数据中可能有重复,需要进行处理! #include <stdio.h> #include <iostream> #include <cstring> ...
- python csv文件打开错误:_csv.Error: line contains NULL byte
当python读取文件出现_csv.Error: line contains NULL byte时, # -*- coding:utf-8 -*- import csv with open(r'E:\ ...
- typescript+react+antd基础环境搭建
typescript+react+antd基础环境搭建(包含样式定制) tsconfig.json 配置 // 具体配置可以看上面的链接 这里module moduleResolution的配置都会影 ...