程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> 關於MYSQL數據庫 >> 用來分析、監控和變換通信數據MySQL-Proxy(1)

用來分析、監控和變換通信數據MySQL-Proxy(1)

編輯:關於MYSQL數據庫

   提示:MySQL- Proxy 處在MySQL數據庫客戶和服務端之間的程序,它支持嵌入性腳本語言Lua。這個代理可以用來分析、監控和變換(transform)通信數據,它支持非常廣泛的使用場景: 負載平衡和故障轉移處理 查詢分析和日志 SQL宏(SQL Macros) 查詢重寫(query rewriting) 執行 shell


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到一個從數據庫

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved