MySQL-Proxy處在MySQL數據庫客戶和服務端之間的程序,它支持嵌入性腳本語言Lua。這個代理可以用來分析、監控和變換(transform)通信數據,它支持非常廣泛的使用場景:
1·負載平衡和故障轉移處理
2·查詢分析和日誌
3·SQL宏(SQL macros)
4·查詢重寫(query rewriting)
5·執行shell命令
MySQL Proxy最強大的一項功能是實現“讀寫分離(Read/Write Splitting)”。基本的原理是讓主數據庫處理事務性查詢,而從數據庫處理SELECT查詢。數據庫複製被用來把事務性查詢導致的變更同步到集羣中的從數據庫。
爲了實現讀寫分離我們需要連接池。我們僅在已打開了到一個後端的一條經過認證的連接的情況下,才切換到該後端。MySQL協議首先進行握手。當進入到查詢/返回結果的階段再認證新連接就太晚了。我們必須保證擁有足夠的打開的連接才能保持運作正常。
實現讀寫分離的LUA腳本: