程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> mysql 讀寫分別(基本篇)

mysql 讀寫分別(基本篇)

編輯:MySQL綜合教程

mysql 讀寫分別(基本篇)。本站提示廣大學習愛好者:(mysql 讀寫分別(基本篇))文章只能為提供參考,不一定能成為您想要的結果。以下是mysql 讀寫分別(基本篇)正文


根本的道理是讓主數據庫處置事務性查詢,而從數據庫處置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

正文:此技能還可以用來完成其他的數據散布戰略,例如分片(Sharding)。

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