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

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

編輯:關於MYSQL數據庫
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


  注釋:此技巧還可以用來實現其他的數據分布策略,例如分片(Sharding)。

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