mysql++ 中遇到的安裝問題 及linux下C++添加共享庫

linux下安裝mysql++

官方網站下載mysql++

tar 命令解壓

./configure --prefix=/local   //安裝路徑自定義

問題:

checking for MySQL library directory... configure: error: Didn't find mysqlclient library in '/usr/lib64 /usr/lib /usr/lib64/mysql /usr/lib/mysql /usr/local/lib64 /usr/local/lib /usr/local/lib/mysql /usr/local/mysql/lib /usr/local/mysql/lib/mysql /usr/mysql/lib/mysql /opt/mysql/lib /opt/mysql/lib/mysql /sw/lib /sw/lib/mysql'

解決方法:sudo apt-get install libmysqlclient

然後locate libmysqlclient去查找你的系統中的libmysqlclient.so library在哪個文件下(我的/usr/lib/x86_64-linux-gnu)

注意:(使用locate之前先sudo updatedb手動更新數據庫下,因爲locate是經過數據庫來查找的,而數據庫默認自動更新是一天一次。這樣可能導致你locate不到今天剛剛生成的文件)

重新使用命令:./configure --prefix=/local --with-mysql-lib=/usr/lib/x86_64-linux-gnu

問題消除 ,

make

sudo make install


測試連接mysql demo

#include <mysql++.h>
#include <iostream>

using namespace std;
int main(int argc, char *argv[])
{
	// Get database access parameters from command line
	const char* db = 0, *server = 0, *user = 0, *password = "";
	db = "healthcareweb";
	server = "11.0.17.208";
	user = "root";
	password = "123456";
	// Connect to the sample database.
	mysqlpp::Connection conn(false);
	if (conn.connect(db, server, user, password)) {
		cout << "success. " << endl;
	} else {
		cout << "false. " << endl;
	}
	return 0;
}

g++ -o main main.cpp -I /home/onejian/local/include/mysql++ -I /usr/include/mysql -L /home/onejian/local/lib -lmysqlpp
(/home/onejian/local/即安裝的路徑,另外mysql_version.h在/usr/include/mysql中所以需要添加,-L 包含庫的路徑)

遇到問題:

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

原因:

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中, 如下:

# cat /etc/ld.so.conf
include ld.so.conf.d/*.conf
# echo "/usr/local/lib" >> /etc/ld.so.conf  
# 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   

一般來講這只是一種臨時的解決方案, 在沒有權限或臨時需要的時候使用.

採用第二種解決方法。解決了問題,完成安裝

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章