MySQL-Proxy, 6月份發布的 MySQL-Proxy是處在你的MySQL數據庫客戶和服務端之間的程序,它還支持嵌入性腳本語言 Lua 。這個代理可以用來分析、監控和變換(transform)通信數據,它支持非常廣泛的使用場景:
- 負載平衡和故障轉移處理
- 查詢分析和日志
- SQL宏(SQL macros)
- 查詢重寫(query rewriting)
- 執行shell命令
MySQL Proxy更強大的一項功能是實現“ 讀寫分離(Read/Write Splitting) ”。基本的原理是讓主數據庫處理事務性查詢,而從數據庫處理SELECT查詢。數據庫復制被用來把事務性查詢導致的變更同步到集群中的從數據庫。
Jan Kneschke在《 MySQL Proxy learns R/W Splitting 》中介紹了這種技巧,他還談到了連接池的問題:
為了實現讀寫分離我們需要連接池。我們僅在已打開了到一個后端的一條經過認證的連接的情況下,才切換到該后端。MySQL協議首先進行握手。當進入到查詢/返回結果的階段再認證新連接就太晚了。我們必須保證擁有足夠的打開的連接才能保持運作正常。
實現讀寫分離的LUA腳本是簡單明了的:
? -- 讀寫分離 ? -- ? -- 發送所有的非事務性SELECT到一個從數據庫 ? 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] ????? -- 選擇一個擁有空閑連接的從數據庫 ????? 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 ??? -- 我們找到了一個擁有空閑連接的從數據庫 ??? if max_conns_ndx > 0 then ????? proxy.connection.backend_ndx = max_conns_ndx ??? end ? else ??? -- 發送到主數據庫 ? end ? return proxy.PROXY_SEND_QUERY
Jan提醒說這個技巧還可以用來實現其他的數據分布策略,例如分片(Sharding)。
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
