用MySQL Proxy實現讀寫分離

2021-06-16 06:20:19 字數 1401 閱讀 3659

mysql-proxy, 6月份發布的mysql-proxy是處在你的mysql資料庫客戶和服務端之間的程式,它還支援嵌入性指令碼語言lua

。這個**可以用來分析、監控和變換(transform)通訊資料,它支援非常廣泛的使用場景:

mysql proxy更強大的一項功能是實現「讀寫分離(read/write splitting)

」。基本的原理是讓主資料庫處理事務性查詢,而從資料庫處理select查詢。資料庫複製被用來把事務性查詢導致的變更同步到集群中的從資料庫。

jan kneschke在《mysql proxy learns r/w splitting

》中介紹了這種技巧,他還談到了連線池的問題:

為了實現讀寫分離我們需要連線池。我們僅在已開啟了到乙個後端的一條經過認證的連線的情況下,才切換到該後端。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

jan提醒說這個技巧還可以用來實現其他的資料分布策略,例如分片(sharding)。

檢視英文原文:read/write splitting with mysql-proxy

用MySQL Proxy實現讀寫分離

mysql proxy,6月份發布的mysql proxy是處在你的mysql資料庫客戶和服務端之間的程式,它還支援嵌入性指令碼語言lua。這個 可以用來分析 監控和變換 transform 通訊資料,它支援非常廣泛的使用場景 mysql proxy更強大的一項功能是實現 讀寫分離 read wri...

mysql proxy讀寫分離

server1 192.168.2.32 server2 192.168.2.114 1 先做主從s1為主,s2為從。2 安裝mysql proxy到s1 wget 解壓安裝包 tar zxvf mysql proxy 0.8.4 linux glibc2.3 x86 64bit.tar.gz配置服...

mysql proxy 讀寫分離

mysql replication可以將master的資料複製分布到多個sl e上,然後利用sl e來分擔master的讀壓力。mysql proxy 是處在mysql資料庫客戶端和服務端之間的程式,它支援嵌入lua。這個 可以用來分析 監控和變換通訊資料,支援非常廣泛的使用場景 mysql pro...