mysql C api 多執行緒多連線 客戶端實現

2021-07-12 03:38:26 字數 1612 閱讀 5345

mysql客戶端庫總是執行緒安全的。

對於除mysql_real_connect()外的所有函式,在預設情況下其他mysql提供給我們的c api函式都是執行緒安全的。

要想使mysql_real_connect()成為執行緒安全的,必須用下述命令再次編譯客戶端庫:

shell> ./configure –enable-thread-safe-client

它建立了執行緒安全客戶端庫libmysqlclient_r。

要想使這些操作平穩工作,需要採取下述措施:

如果程式在呼叫mysql_real_connect()之前需要呼叫任何其他mysql函式,請在啟動程式時呼叫my_init()(my_init()會在mysql_init中呼叫)。

將客戶端鏈結到libmysqlclient_r時,如果存在未定義的符號,可能會出錯(記憶體洩漏)。在大多數情況下,其原因在於,未將執行緒庫包含在link/compile行上。

測試**:

#include 

#include

#include

#include

#include

#include

#include

#include

#include

void* work(void* arg)

if(!mysql_real_connect(m_pdbaccess, "192.168.1.203", "root", "123456", "tposdb", 0, null, client_multi_statements))

mysql_autocommit(m_pdbaccess, 0);

char value = 1;

mysql_options(m_pdbaccess, mysql_opt_reconnect, (char*)&value);

if (mysql_query(m_pdbaccess, "call getbankserialno('35220001', '310111173110010');")) // 如果失敗

// mysql_rollback(m_pdbaccess);

mysql_query(m_pdbaccess,"commit");

mysql_close(m_pdbaccess);

m_pdbaccess = null ;

//在多執行緒環境下把下邊語句注釋掉使用

//mysql_thread_end();

return null;

}int main(int rgvs, char **rgva)

sleep(5);

return

0;}

編譯命令:

gcc test.c -o test -l/usr/lib64/mysql -lmysqlclient_r

-lpthread

測試命令:

valgrind--

tool=memcheck--

leak

-check=full

./test

對比有mysql_thread_end();和無mysql_thread_end();的結果

多執行緒連線MySql

一 前置條件 1 linux 已經安裝好 mysql 資料庫 2 linux 已經安裝了 gcc 編譯器 二 資料庫準備 為了便於描述,假設資料庫的 root 使用者密碼為 root。1 以 root 使用者登陸資料庫 mysql u root p mysql 2 建立資料 testdb mysql...

多執行緒 執行緒池執行多業務邏輯

1.執行緒池執行不同的業務邏輯.2.獲取每個任務執行的結果 3.最後的結果會用到之前的結果 public class searchuserlistdto catch interruptedexception e system.out.println 111 乙個執行緒池,三個執行緒,執行三個任務,只...

python多執行緒下連線SQL server

import pymssql from dbutils.pooleddb import pooleddb class connsql object def init self self.pool self.create pool def create pool self 建立資料庫連線池 retur...