mysql 讀寫分離(實戰(zhàn)篇)
更新時間:2009年04月13日 11:12:28 作者:
MySQL Proxy最強(qiáng)大的一項功能是實現(xiàn)“讀寫分離(Read/Write Splitting)”。
MySQL Proxy最強(qiáng)大的一項功能是實現(xiàn)“讀寫分離(Read/Write Splitting)”?;镜脑硎亲屩鲾?shù)據(jù)庫處理事務(wù)性查詢,而從數(shù)據(jù)庫處理SELECT查詢。數(shù)據(jù)庫復(fù)制被用來把事務(wù)性查詢導(dǎo)致的變更同步到集群中的從數(shù)據(jù)庫。

Jan Kneschke在《MySQL Proxy learns R/W Splitting》中詳細(xì)的介紹了這種技巧以及連接池問題:
為了實現(xiàn)讀寫分離我們需要連接池。我們僅在已打開了到一個后端的一條經(jīng)過認(rèn)證的連接的情況下,才切換到該后端。MySQL協(xié)議首先進(jìn)行握手。當(dāng)進(jìn)入到查詢/返回結(jié)果的階段再認(rèn)證新連接就太晚了。我們必須保證擁有足夠的打開的連接才能保持運(yùn)作正常。
實現(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)。

Jan Kneschke在《MySQL Proxy learns R/W Splitting》中詳細(xì)的介紹了這種技巧以及連接池問題:
為了實現(xiàn)讀寫分離我們需要連接池。我們僅在已打開了到一個后端的一條經(jīng)過認(rèn)證的連接的情況下,才切換到該后端。MySQL協(xié)議首先進(jìn)行握手。當(dāng)進(jìn)入到查詢/返回結(jié)果的階段再認(rèn)證新連接就太晚了。我們必須保證擁有足夠的打開的連接才能保持運(yùn)作正常。
實現(xiàn)讀寫分離的LUA腳本:
復(fù)制代碼 代碼如下:
-- 讀寫分離
--
-- 發(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ù)制、讀寫分離、備份恢復(fù)
- MySQL5.6 Replication主從復(fù)制(讀寫分離) 配置完整版
- MySQL主從復(fù)制的原理及配置方法(比較詳細(xì))
- linux系統(tǒng)下實現(xiàn)mysql熱備份詳細(xì)步驟(mysql主從復(fù)制)
- Mysql主從復(fù)制(master-slave)實際操作案例
- MySQL的主從復(fù)制步驟詳解及常見錯誤解決方法
- MySQL主從復(fù)制配置心跳功能介紹
- MySQL主從同步、讀寫分離配置步驟
- mysql 讀寫分離(基礎(chǔ)篇)
- MySQL的使用中實現(xiàn)讀寫分離的教程
- mysql主從復(fù)制讀寫分離的配置方法詳解
相關(guān)文章
mysql數(shù)據(jù)庫和oracle數(shù)據(jù)庫之間互相導(dǎo)入備份
今天小編就為大家分享一篇關(guān)于mysql數(shù)據(jù)庫和oracle數(shù)據(jù)庫之間互相導(dǎo)入備份,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-04-04
MySQL中查詢當(dāng)前時間間隔前1天的數(shù)據(jù)
實際項目中我們都會遇到分布式定時任務(wù)執(zhí)行的情況,今天通過本文給大家分享MySQL中查詢當(dāng)前時間間隔前1天的數(shù)據(jù),查詢sql語句給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧<BR>2021-12-12
mysql存儲過程之引發(fā)存儲過程中的錯誤條件(SIGNAL和RESIGNAL語句)實例分析
這篇文章主要介紹了mysql存儲過程之引發(fā)存儲過程中的錯誤條件(SIGNAL和RESIGNAL語句),結(jié)合實例形式分析了mysql使用SIGNAL和RESIGNAL語句來引發(fā)存儲過程中的錯誤條件相關(guān)操作技巧與注意事項,需要的朋友可以參考下2019-12-12
mysql將bin-log日志文件轉(zhuǎn)為sql文件的方法
這篇文章主要介紹了mysql將bin-log日志文件轉(zhuǎn)為sql文件的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-12-12
navicat創(chuàng)建MySql定時任務(wù)的方法詳解
這篇文章主要介紹了navicat創(chuàng)建MySql定時任務(wù)的方法詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10
創(chuàng)建一個實現(xiàn)Disqus評論模版的MySQL模型
這篇文章主要介紹了創(chuàng)建一個實現(xiàn)Disqus評論模版的MySQL模型,Disqus網(wǎng)站的數(shù)據(jù)庫采用PostgreSQL,而作者則以MySQL來實現(xiàn),需要的朋友可以參考下2015-06-06

