《Mysql實(shí)例mysql 讀寫分離(基礎(chǔ)篇)》要點(diǎn):
本文介紹了Mysql實(shí)例mysql 讀寫分離(基礎(chǔ)篇),希望對您有用。如果有疑問,可以聯(lián)系我們。
基本的原理是讓主數(shù)據(jù)庫處理事務(wù)性查詢,而從數(shù)據(jù)庫處理SELECT查詢.數(shù)據(jù)庫復(fù)制被用來把事務(wù)性查詢導(dǎo)致的變更同步到集群中的從數(shù)據(jù)庫.

MYSQL必讀 Jan Kneschke在《MySQL Proxy learns R/W Splitting》中詳細(xì)的介紹了這種技巧以及連接池問題:
MYSQL必讀 為了實(shí)現(xiàn)讀寫分離我們需要連接池.我們僅在已打開了到一個后端的一條經(jīng)過認(rèn)證的連接的情況下,才切換到該后端.MySQL協(xié)議首先進(jìn)行握手.當(dāng)進(jìn)入到查詢/返回結(jié)果的階段再認(rèn)證新連接就太晚了.我們必須保證擁有足夠的打開的連接才能保持運(yùn)作正常.
實(shí)現(xiàn)讀寫分離的LUA腳本:
-- 讀寫分離
--
-- 發(fā)送所有的非事務(wù)性Select到一個從數(shù)據(jù)庫
代碼如下:
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]
-- 需要選擇一個擁有空閑連接的從數(shù)據(jù)庫
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
-- 至此,我們找到了一個擁有空閑連接的從數(shù)據(jù)庫
if max_conns_ndx > 0 then
proxy.connection.backend_ndx = max_conns_ndx
end
else
-- 發(fā)送到主數(shù)據(jù)庫
end
return proxy.PROXY_SEND_QUERY
注釋:此技巧還可以用來實(shí)現(xiàn)其他的數(shù)據(jù)分布策略,例如分片(Sharding).
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.snjht.com/jiaocheng/2696.html