日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

用MySQL-Proxy實(shí)現(xiàn)讀寫(xiě)分離

系統(tǒng) 2185 0

MySQL-Proxy, 6月份發(fā)布的 MySQL-Proxy是處在你的MySQL數(shù)據(jù)庫(kù)客戶和服務(wù)端之間的程序,它還支持嵌入性腳本語(yǔ)言 Lua 。這個(gè)代理可以用來(lái)分析、監(jiān)控和變換(transform)通信數(shù)據(jù),它支持非常廣泛的使用場(chǎng)景:

  • 負(fù)載平衡和故障轉(zhuǎn)移處理
  • 查詢分析和日志
  • SQL宏(SQL macros)
  • 查詢重寫(xiě)(query rewriting)
  • 執(zhí)行shell命令

MySQL Proxy更強(qiáng)大的一項(xiàng)功能是實(shí)現(xiàn)“ 讀寫(xiě)分離(Read/Write Splitting) ”。基本的原理是讓主數(shù)據(jù)庫(kù)處理事務(wù)性查詢,而從數(shù)據(jù)庫(kù)處理SELECT查詢。數(shù)據(jù)庫(kù)復(fù)制被用來(lái)把事務(wù)性查詢導(dǎo)致的變更同步到集群中的從數(shù)據(jù)庫(kù)。

Jan Kneschke在《 MySQL Proxy learns R/W Splitting 》中介紹了這種技巧,他還談到了連接池的問(wèn)題:

為了實(shí)現(xiàn)讀寫(xiě)分離我們需要連接池。我們僅在已打開(kāi)了到一個(gè)后端的一條經(jīng)過(guò)認(rèn)證的連接的情況下,才切換到該后端。MySQL協(xié)議首先進(jìn)行握手。當(dāng)進(jìn)入到查詢/返回結(jié)果的階段再認(rèn)證新連接就太晚了。我們必須保證擁有足夠的打開(kāi)的連接才能保持運(yùn)作正常。

實(shí)現(xiàn)讀寫(xiě)分離的LUA腳本是簡(jiǎn)單明了的:

    ? -- 讀寫(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

  

Jan提醒說(shuō)這個(gè)技巧還可以用來(lái)實(shí)現(xiàn)其他的數(shù)據(jù)分布策略,例如分片(Sharding)。

查看英文原文: Read/Write Splitting with MySQL-Proxy

用MySQL-Proxy實(shí)現(xiàn)讀寫(xiě)分離


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對(duì)您有幫助就好】

您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦!!!

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 资阳市| 会宁县| 正宁县| 拉萨市| 南雄市| 乌鲁木齐县| 德江县| 房山区| 涿鹿县| 福建省| 陇南市| 连云港市| 辽中县| 徐闻县| 潜山县| 清镇市| 南汇区| 株洲市| 久治县| 石林| 固安县| 三门县| 涡阳县| 宜宾县| 德江县| 安岳县| 泰安市| 灵宝市| 新田县| 柯坪县| 宜宾市| 潮州市| 当阳市| 崇明县| 中卫市| 漠河县| 辽阳县| 克什克腾旗| 扶余县| 江华| 鄱阳县|