mysql 讀寫分離(基礎(chǔ)篇)
Jan Kneschke在《MySQL Proxy learns R/W Splitting》中詳細的介紹了這種技巧以及連接池問題:
為了實現(xiàn)讀寫分離我們需要連接池。我們僅在已打開了到一個后端的一條經(jīng)過認證的連接的情況下,才切換到該后端。MySQL協(xié)議首先進行握手。當進入到查詢/返回結(jié)果的階段再認證新連接就太晚了。我們必須保證擁有足夠的打開的連接才能保持運作正常。
實現(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
注釋:此技巧還可以用來實現(xiàn)其他的數(shù)據(jù)分布策略,例如分片(Sharding)。
- MySQL主從復(fù)制的原理及配置方法(比較詳細)
- Mysql主從復(fù)制(master-slave)實際操作案例
- MySQL的主從復(fù)制步驟詳解及常見錯誤解決方法
- 詳解MySQL實現(xiàn)主從復(fù)制過程
- MySQL數(shù)據(jù)庫InnoDB引擎主從復(fù)制同步經(jīng)驗總結(jié)
- Mysql 5.7從節(jié)點配置多線程主從復(fù)制的方法詳解
- 詳解MySQL的主從復(fù)制、讀寫分離、備份恢復(fù)
- mysql主從復(fù)制讀寫分離的配置方法詳解
- MySQL主從同步、讀寫分離配置步驟
- 使用PHP實現(xiàn)Mysql讀寫分離
- MySQL主從復(fù)制與讀寫分離原理及用法詳解
相關(guān)文章
Mysql數(shù)據(jù)庫時間與系統(tǒng)時間不一致問題排查及解決
最近忽然發(fā)現(xiàn)個問題,Mysql數(shù)據(jù)庫時間與系統(tǒng)時間不一致,通過查找相關(guān)資料終于解決了,下面這篇文章主要給大家介紹了關(guān)于Mysql數(shù)據(jù)庫時間與系統(tǒng)時間不一致問題排查及解決的相關(guān)資料,需要的朋友可以參考下2023-06-06
Mysql version can not be less than 4.1 出錯解決辦法
這篇文章主要介紹了Mysql version can not be less than 4.1 解決辦法的相關(guān)資料,需要的朋友可以參考下2016-10-10

