mysql的讀寫分離(基礎篇)

2021-06-16 02:21:38 字數 1069 閱讀 6308

mysql proxy最強大的一項功能是實現「讀寫分離(read/write splitting)」。基本的原理是讓主資料庫處理事務性查詢,而從資料庫處理select查詢。資料庫複製被用來把事務性查詢導致的變更同步到集群中的從資料庫。

為了實現讀寫分離我們需要連線池。我們僅在已開啟了到乙個後端的一條經過認證的連線的情況下,才切換到該後端。mysql協議首先進行握手。當進入到查詢/返回結果的階段再認證新連線就太晚了。我們必須保證擁有足夠的開啟的連線才能保持運作正常。

實現讀寫分離的lua指令碼:

-- 讀寫分離

-- 傳送所有的非事務性select到乙個從資料庫

if is_in_transaction == 0 and

packet:byte() == proxy.com_query and

packet:sub(2, 7) == "select" then

local max_conns = -1

local max_conns_ndx = 0

for i = 1, #proxy.servers do

local s = proxy.servers[i]

-- 需要選擇乙個擁有空閒連線的從資料庫

if s.type == proxy.backend_type_ro and

s.idling_connections > 0 then

if max_conns == -1 or

s.connected_clients < max_conns then

max_conns = s.connected_clients

max_conns_ndx = i

endend

end-- 至此,我們找到了乙個擁有空閒連線的從資料庫

if max_conns_ndx > 0 then

proxy.connection.backend_ndx = max_conns_ndx

endelse

-- 傳送到主資料庫

endreturn proxy.proxy_send_query

注釋:此技巧還可以用來實現其他的資料分布策略,例如分片(sharding)。

mysql 讀寫分離(基礎篇)

基本的原理是讓主資料庫處理事務性查詢,而從資料庫處理select查詢。資料庫複製被用來把事務性查詢導致的變更同步到集群中的從資料庫。jan kneschke在 mysql proxy learns r w splitting 中詳細的介紹了這種技巧以及連線池問題 為了實現讀寫分離我們需要連線池。我們...

mysql 讀寫分離(實戰篇)

mysql proxy最強大的一項功能是實現 讀寫分離 read write splitting 基本的原理是讓主資料庫處理事務性查詢,而從資料庫處理select查詢。資料庫複製被用來把事務性查詢導致的變更同步到集群中的從資料庫。jan knes在 mysql prox程式設計客棧y learns ...

mysql讀寫分離

5.讀寫分離適用與讀遠大於寫的場景,如果只有一台伺服器,當select很多時,update和delete會被這些select訪問中的資料堵塞,等待select結束,併發效能不高。對於寫和讀比例相近的應用,應該部署雙主相互複製。6.可以在從庫啟動是增加一些引數來提高其讀的效能,例如 skip inno...