mysql 讀寫(xiě)分離(實(shí)戰(zhàn)篇)

mysql Proxy最強(qiáng)大的一項(xiàng)功能是實(shí)現(xiàn)“讀寫(xiě)分離(Read/Write Splitting)”。

MySQL Proxy最強(qiáng)大的一項(xiàng)功能是實(shí)現(xiàn)“讀寫(xiě)分離(Read/Write Splitting)”。基本的原理是讓主數(shù)據(jù)庫(kù)處理事務(wù)性查詢,而從數(shù)據(jù)庫(kù)處理SELECT查詢。數(shù)據(jù)庫(kù)復(fù)制被用來(lái)把事務(wù)性查詢導(dǎo)致的變更同步到集群中的從數(shù)據(jù)庫(kù)。

  Jan Kneschke在《MySQL Proxy learns R/W Splitting》中詳細(xì)的介紹了這種技巧以及連接池問(wèn)題:
  為了實(shí)現(xiàn)讀寫(xiě)分離我們需要連接池。我們僅在已打開(kāi)了到一個(gè)后端的一條經(jīng)過(guò)認(rèn)證的連接的情況下,才切換到該后端。MySQL協(xié)議首先進(jìn)行握手。當(dāng)進(jìn)入到查詢/返回結(jié)果的階段再認(rèn)證新連接就太晚了。我們必須保證擁有足夠的打開(kāi)的連接才能保持運(yùn)作正常。
  實(shí)現(xiàn)讀寫(xiě)分離的LUA腳本:
   代碼如下:
— 讀寫(xiě)分離
  –
  – 發(fā)送所有的非事務(wù)性Select到一個(gè)從數(shù)據(jù)庫(kù)
  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]
  – 需要選擇一個(gè)擁有空閑連接的從數(shù)據(jù)庫(kù)
  if s.type == proxy.BACKEND_TYPE_RO and
  s.idling_connections > 0 then
  if max_conns == -1 or
  s.connected_clients   max_conns = s.connected_clients
  max_conns_ndx = i
  end
  end
  end
  – 至此,我們找到了一個(gè)擁有空閑連接的從數(shù)據(jù)庫(kù)
  if max_conns_ndx > 0 then
  proxy.connection.backend_ndx = max_conns_ndx
  end
  else
  – 發(fā)送到主數(shù)據(jù)庫(kù)
  end
  return proxy.PROXY_SEND_QUERY

  注釋:此技巧還可以用來(lái)實(shí)現(xiàn)其他的數(shù)據(jù)分布策略,例如分片(Sharding)。

? 版權(quán)聲明
THE END
喜歡就支持一下吧
點(diǎn)贊15 分享