mysql proxy最強大的一項功能是實現「讀寫分離(read/write splitting)」。基本的原理是讓主資料庫處理事務性查詢,而從資料庫處理select查詢。資料庫複製被用來把事務性查詢導致的變更同步到集群中的從資料庫。
jan knes在《mysql prox程式設計客棧y 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
end
end
end
-- 至此,我們找到了乙個擁有空閒連線的從資料庫
if max_conns_ndx > 0 then
proxy.connection.backend_ndx = max_conns_ndx
end
else
-- 傳送到主資料庫
end
return proxy.proxy_send_query
注釋:此技巧還可以用來實現其他的資料分布策略,例如分片(sharding)。
本文標題: mysql 讀寫分離(實戰篇)
本文位址: /shujuku/mysql/47419.html
mysql索引 實戰 mysql索引 實戰篇
索引主要用於快速的檢索資料,對於一萬條以上的資料不使用索引查詢是災難性的。從不同的維度上有不同的索引定義 如b tree索引,hash索引,位圖索引,鏈結索引,聚集索引,非聚集索引,覆蓋索引.等等。本文主要討論mysql innodb和mysian 下的b tree索引,第一部分主要討論常用sql語...
mysql 讀寫分離(基礎篇)
基本的原理是讓主資料庫處理事務性查詢,而從資料庫處理select查詢。資料庫複製被用來把事務性查詢導致的變更同步到集群中的從資料庫。jan kneschke在 mysql proxy learns r w splitting 中詳細的介紹了這種技巧以及連線池問題 為了實現讀寫分離我們需要連線池。我們...
spring aop 實戰篇 一
需求 通過spring aop 提供的面向切面程式設計的思想,利用自定義註解的方式,實現對介面的功能的增強 一 自定義乙個註解類 target 指明了修飾的這個註解的使用範圍,即被描述的註解可以用在 documented retention retentionpolicy.runtime targe...