mysql 讀寫(xiě)分離(基礎(chǔ)篇)
Jan Kneschke在《MySQL Proxy learns R/W Splitting》中詳細(xì)的介紹了這種技巧以及連接池問(wèn)題:
為了實(shí)現(xiàn)讀寫(xiě)分離我們需要連接池。我們僅在已打開(kāi)了到一個(gè)后端的一條經(jīng)過(guò)認(rèn)證的連接的情況下,才切換到該后端。MySQL協(xié)議首先進(jìn)行握手。當(dāng)進(jìn)入到查詢(xún)/返回結(jié)果的階段再認(rèn)證新連接就太晚了。我們必須保證擁有足夠的打開(kāi)的連接才能保持運(yùn)作正常。
實(shí)現(xiàn)讀寫(xiě)分離的LUA腳本:
-- 讀寫(xiě)分離
--
-- 發(fā)送所有的非事務(wù)性Select到一個(gè)從數(shù)據(jù)庫(kù)
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]
-- 需要選擇一個(gè)擁有空閑連接的從數(shù)據(jù)庫(kù)
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
-- 至此,我們找到了一個(gè)擁有空閑連接的從數(shù)據(jù)庫(kù)
if max_conns_ndx > 0 then
proxy.connection.backend_ndx = max_conns_ndx
end
else
-- 發(fā)送到主數(shù)據(jù)庫(kù)
end
return proxy.PROXY_SEND_QUERY
注釋?zhuān)捍思记蛇€可以用來(lái)實(shí)現(xiàn)其他的數(shù)據(jù)分布策略,例如分片(Sharding)。
- MySQL主從復(fù)制的原理及配置方法(比較詳細(xì))
- Mysql主從復(fù)制(master-slave)實(shí)際操作案例
- MySQL的主從復(fù)制步驟詳解及常見(jiàn)錯(cuò)誤解決方法
- 詳解MySQL實(shí)現(xiàn)主從復(fù)制過(guò)程
- MySQL數(shù)據(jù)庫(kù)InnoDB引擎主從復(fù)制同步經(jīng)驗(yàn)總結(jié)
- Mysql 5.7從節(jié)點(diǎn)配置多線程主從復(fù)制的方法詳解
- 詳解MySQL的主從復(fù)制、讀寫(xiě)分離、備份恢復(fù)
- mysql主從復(fù)制讀寫(xiě)分離的配置方法詳解
- MySQL主從同步、讀寫(xiě)分離配置步驟
- 使用PHP實(shí)現(xiàn)Mysql讀寫(xiě)分離
- MySQL主從復(fù)制與讀寫(xiě)分離原理及用法詳解
相關(guān)文章
JDK1.7下測(cè)試ConnectorJ連接MySQL8.0的方法
MySQL?Connector/J是一個(gè)JDBC?4型驅(qū)動(dòng)程序。Type?4標(biāo)志意味著驅(qū)動(dòng)程序是MySQL協(xié)議的純Java實(shí)現(xiàn),不依賴(lài)于MySQL客戶(hù)端庫(kù),這篇文章主要介紹了JDK1.7下測(cè)試ConnectorJ連接MySQL8.0,需要的朋友可以參考下2022-10-10
使用Mysql5.x以上版本出現(xiàn)報(bào)錯(cuò)#1929 Incorrect datetime value: '''''''' f
我的MySQL安裝后,保存刪除表數(shù)據(jù)總是出現(xiàn)#1929 Incorrect datetime value: '' for column 'createtime' 的報(bào)錯(cuò)提醒,導(dǎo)致不能刪除表里數(shù)據(jù)。下面小編給大家分析原因及解決辦法,需要的朋友可以參考下2017-01-01
MariaDB 新版本實(shí)力逆襲不僅僅是 MySQL 替代品
MariaDB是MySQL源代碼的一個(gè)分支,主要由開(kāi)源社區(qū)在維護(hù),采用GPL授權(quán)許可。MariaDB 10.0和MySQL 5.6的不同之處有那些,MariaDB和Percona有什么不同呢?下面通過(guò)本文詳細(xì)了解下吧2016-12-12
在阿里云的CentOS環(huán)境中安裝配置MySQL的教程
這篇文章主要介紹了在阿里云的CentOS環(huán)境中安裝配置MySQL的教程,注意一下文章開(kāi)頭所提到的系統(tǒng)自帶MariaDB的問(wèn)題,需要的朋友可以參考下2015-12-12
mysql 5.7.13 winx64安裝配置方法圖文教程(win10)
這篇文章主要為大家分享了mysql 5.7.13 winx64安裝配置方法圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01

