如何使用"MySQL-Proxy"实现读写分离

2016-02-19 19:52 3 1 收藏

今天图老师小编要向大家分享个如何使用"MySQL-Proxy"实现读写分离教程,过程简单易学,相信聪明的你一定能轻松get!

【 tulaoshi.com - 编程语言 】

  MySQL-Proxy处在MySQL数据库客户和服务端之间的程序,它支持嵌入性脚本语言Lua。这个代理可以用来分析、监控和变换(transform)通信数据,它支持非常广泛的使用场景:

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

  ·负载平衡和故障转移处理

  ·查询分析和日志

  ·SQL宏(SQL macros)

  ·查询重写(query rewriting)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

  ·执行shell命令

  MySQL Proxy最强大的一项功能是实现“读写分离(Read/Write Splitting)”。基本的原理是让主数据库处理事务性查询,而从数据库处理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)。

来源:https://www.tulaoshi.com/n/20160219/1622093.html

延伸阅读
虽然关于Java字符串“==”和“equals”的问题是Java学习中的最基础的一个问题,但是仍然有不少刚刚学习Java的同学搞不清楚里面的原理,最近和朋友讨论到这个问题,所以写篇文章给大家分享一下我自己的理解。 首先让我们看一个例子: 代码如下:     public class TestStringEquals {       ...
意外宝宝并非喜从天降 很多80后、90后将非计划 怀孕 美其名曰为喜从天降,视奉子成婚为水到渠成。然而事实并非想象那么完美,无数 新生儿 病例证明:这些来自于非计划怀孕的意外宝宝往往意味着胚胎命运多舛。 意外宝宝难保质量非计划怀孕导致孕前补充叶酸、接种疫苗等措施被耽误,胎儿质(图老师整理)量总体上比...
标签: Web开发
在网上找到一个用ASP开的假线程,发现和我以前做的一个程序不谋而合,只不过以前用的是VB,摘下来,储备. 1.原理实验 原理当然都一样,利用web服务器支持多线程,在同一页面里向服务器发多个http请求来完成我们的工作。还是先实验一下,在一个页面里同时写2个txt文件,比较写入时间的差异。代码如下: % startime=timer() ''----------asp实现多...
标签: Web开发
A common UI is to have a table of data rows, which when clicked on expand to show a detailed breakdown of "child" rows below the "parent" row. The only requirements ar...
标签: 养生 健康
茶是中国老百姓非常喜爱的一种饮品,有的人甚至是一年四季以茶代水,茶不离口,甚至用茶来治病。专家提醒:茶水虽好,但冬季喝茶还有很多讲究。据专家介绍:冬天人的机体生理活动处于抑制状态,对于冬天的人们来说,养生之道在于御寒保暖,尤其是老年人到了冬季,抵抗力下降,手脚容易出现冰凉的现象,如果此时再喝上一杯绿茶,那只会更加重寒气...

经验教程

909

收藏

79
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部