原文:http://chenzhou123520.iteye.com/blog/1925196
linux上啟動Memcache報錯:
原因一般有兩個, 一個是操作系統里確實沒有包含該共享庫(lib*.so.*文件)或者共享庫版本不對, 遇到這種情況那就去網上下載並安裝上即可.
另外一個原因就是已經安裝了該共享庫, 但執行需要調用該共享庫的程序的時候, 程序按照默認共享庫路徑找不到該共享庫文件.
因為我已經安裝了libevent,所以應該是程序按照默認共享路徑庫去找,但是沒有找到導致的。
首先使用find命令找到libevent-1.4.so.2文件在哪兒
使用debug信息查看程序去哪里尋找共享文件庫
-
LD_DEBUG=libs /usr/local/bin/memcached -v
其中/usr/local/bin/memcached代表我memcached執行程序
控制台輸出結果如下:
-
[root@localhost memcached]# LD_DEBUG=libs /usr/local/bin/memcached -v -bash: /usr/local/bin/memcached: No such file or directory [root@localhost memcached]# LD_DEBUG=libs /usr/local/memcached/bin/memcached -v 6513: find library=libevent-1.4.so.2 [0]; searching 6513: search cache=/etc/ld.so.cache 6513: search path=/lib/tls/i686/sse2:/lib/tls/i686:/lib/tls/sse2:/lib/tls:/lib/i686/sse2:/lib/i686:/lib/sse2:/lib:/usr/lib/tls/i686/sse2:/usr/lib/tls/i686:/usr/lib/tls/sse2:/usr/lib/tls:/usr/lib/i686/sse2:/usr/lib/i686:/usr/lib/sse2:/usr/lib (system search path) 6513: trying file=/lib/tls/i686/sse2/libevent-1.4.so.2 6513: trying file=/lib/tls/i686/libevent-1.4.so.2 6513: trying file=/lib/tls/sse2/libevent-1.4.so.2 6513: trying file=/lib/tls/libevent-1.4.so.2 6513: trying file=/lib/i686/sse2/libevent-1.4.so.2 6513: trying file=/lib/i686/libevent-1.4.so.2 6513: trying file=/lib/sse2/libevent-1.4.so.2 6513: trying file=/lib/libevent-1.4.so.2 6513: trying file=/usr/lib/tls/i686/sse2/libevent-1.4.so.2 6513: trying file=/usr/lib/tls/i686/libevent-1.4.so.2 6513: trying file=/usr/lib/tls/sse2/libevent-1.4.so.2 6513: trying file=/usr/lib/tls/libevent-1.4.so.2 6513: trying file=/usr/lib/i686/sse2/libevent-1.4.so.2 6513: trying file=/usr/lib/i686/libevent-1.4.so.2 6513: trying file=/usr/lib/sse2/libevent-1.4.so.2 6513: trying file=/usr/lib/libevent-1.4.so.2 6513: /usr/local/memcached/bin/memcached: error while loading shared libraries: libevent-1.4.so.2: cannot open shared object file: No such file or directory
根據debug日志可以看到,程序只會去/lib 和/usr/lib下去尋找需要的共享鏈接庫。
而我的libevent是安裝在/usr/libevent/lib/下,所以memcache啟動的時候並不知道該去這下面找,所以會報錯
所以安裝共享庫后要注意共享庫路徑設置問題, 如下:
1) 如果共享庫文件安裝到了/lib或/usr/lib目錄下, 那么需執行一下ldconfig命令
ldconfig命令的用途, 主要是在默認搜尋目錄(/lib和/usr/lib)以及動態庫配置文件/etc/ld.so.conf內所列的目錄下, 搜索出可共享的動態鏈接庫(格式如lib*.so*), 進而創建出動態裝入程序(ld.so)所需的連接和緩存文件. 緩存文件默認為/etc/ld.so.cache, 此文件保存已排好序的動態鏈接庫名字列表.
2) 如果共享庫文件安裝到了/usr/local/lib(很多開源的共享庫都會安裝到該目錄下)或其它"非/lib或/usr/lib"目錄下, 那么在執行ldconfig命令前, 還要把新共享庫目錄加入到共享庫配置文件/etc/ld.so.conf中, 如下:
- [root@localhost memcached]# cat /etc/ld.so.conf
- include ld.so.conf.d/*.conf
如上所示:/etc/ld.so.conf配置文件中內容只有一行,
ld.so.conf.d/*.conf的意思就是包含ld.so.conf.d/目錄下以.conf為后綴的文件
所以我們可以在/etc/ld.so.conf.d目錄下新建一個libevent.conf的配置文件,然后把libevent安裝路徑配置好
我的libevent內容如下:
- [root@localhost ld.so.conf.d]# cat libevent.conf
- /usr/libevent/lib
配置完后執行以下ldconfig命令
- [root@localhost ~]#ldconfig
3) 如果共享庫文件安裝到了其它"非/lib或/usr/lib" 目錄下, 但是又不想在/etc/ld.so.conf中加路徑(或者是沒有權限加路徑). 那可以export一個全局變量LD_LIBRARY_PATH, 然后運行程序的時候就會去這個目錄中找共享庫.
LD_LIBRARY_PATH的意思是告訴loader在哪些目錄中可以找到共享庫. 可以設置多個搜索目錄, 這些目錄之間用冒號分隔開. 比如安裝了一個mysql到/usr/local/mysql目錄下, 其中有一大堆庫文件在/usr/local/mysql/lib下面, 則可以在.bashrc或.bash_profile或shell里加入以下語句即可:
export LD_LIBRARY_PATH=/usr/local/mysql/lib:$LD_LIBRARY_PATH
一般來講這只是一種臨時的解決方案, 在沒有權限或臨時需要的時候使用.
這個問題的解決參考了網上的相關資料,特此說明!