首頁 >資料庫 >mysql教程 >mysql 讀寫分離(基礎篇)

mysql 讀寫分離(基礎篇)

黄舟
黄舟原創
2016-12-17 14:18:50971瀏覽

基本的原理是讓主資料庫處理事務性查詢,而從資料庫處理SELECT查詢。資料庫複製被用來把事務性查詢導致的變更同步到叢集中的從資料庫。 mysql 讀寫分離(基礎篇)

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)。 

 以上就是mysql 讀寫分離(基礎篇)的內容,更多相關文章請關注PHP中文網(www.php.cn)!


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn