在使用redis 时,技术选型之后就要开始实际编程,这里我们使用hiredis 进行c++编程。
首先通过编写一个简单的demo 通过设置对应的makefile管理。先测试一下编译问题。
然后,就出现了问题:
[zryTest@master redis_test]$ ./redis_example ./redis_example: error while loading shared libraries: libhiredis.so.1.1.1-dev: cannot open shared object file: No such file or directory
找不到这个库,查看一下服务器上到底有没有。使用find命令
sudo find / -name libhiredis.so.1.1.1-dev
有找到,说明是找不到路径。
使用 -L 命令说明查找路径。
-L/usr/local/lib
但是使用ldd 命令继续查看,显示动态库未链接
[zryTest@master redis_test]$ ldd redis_example linux-vdso.so.1 => (0x00007ffd6d9af000) libhiredis.so.1.1.1-dev => not found libstdc++.so.6 => /lib64/libstdc++.so.6 (0x00007f0eded69000) libm.so.6 => /lib64/libm.so.6 (0x00007f0edea67000) libgcc_s.so.1 => /lib64/libgcc_s.so.1 (0x00007f0ede851000) libc.so.6 => /lib64/libc.so.6 (0x00007f0ede483000) /lib64/ld-linux-x86-64.so.2 (0x00007f0edf071000)
考虑动态库路径没有包含 /usr/local/lib
使用显式设定:-rpath声明路径
-Wl,-rpath=/usr/local/lib
这个选项告诉链接器在运行时搜索动态库时也包含/usr/local/lib路径。
编译通过
[zryTest@master redis_test]$ ldd redis_example linux-vdso.so.1 => (0x00007ffe49312000) libhiredis.so.1.1.1-dev => /usr/local/lib/libhiredis.so.1.1.1-dev (0x00007fbc07890000) libstdc++.so.6 => /lib64/libstdc++.so.6 (0x00007fbc07588000) libm.so.6 => /lib64/libm.so.6 (0x00007fbc07286000) libgcc_s.so.1 => /lib64/libgcc_s.so.1 (0x00007fbc07070000) libc.so.6 => /lib64/libc.so.6 (0x00007fbc06ca2000) /lib64/ld-linux-x86-64.so.2 (0x00007fbc07aa3000)
总结
当使用新的工具或者框架时,从git 上下载的源码编译时,make install 时,不保证存放路径能在当前操作系统路径宏中有。
所以,当发现找不到路径而实际又存在时,使用显式说明指定路径,
另外,如果你使用的是bash shell,可以将/usr/local/lib添加到LD_LIBRARY_PATH环境变量中。在命令行中执行以下命令:
export LD_LIBRARY_PATH=/usr/local/lib:$LD_LIBRARY_PATH
这将临时将/usr/local/lib添加到LD_LIBRARY_PATH环境变量中,使系统能够找到libhiredis.so.1.1.1-dev库文件。请注意,这个方法只在当前会话中有效,如果你希望永久生效,可以将这个命令添加到你的shell配置文件(如~/.bashrc)中。