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

上天没有给你想

上天没有给你想

2016-02-19 19:52

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

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

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

  ·查询分析和日志

  ·SQL宏(SQL macros)

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

  ·查询重写(query rewriting)

(本文来源于图老师网站,更多请访问https://m.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)。

展开更多 50%)
分享

猜你喜欢

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

编程语言 网络编程
如何使用"MySQL-Proxy"实现读写分离

饮茶的"宜"与"忌"

养生 健康
饮茶的"宜"与"忌"

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

java中"==" 与equals方法的使用

编程语言 网络编程
java中"==" 与equals方法的使用

用js怎么把&字符换成"&amp:"

Web开发
用js怎么把&字符换成"&amp:"

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

mysql "too many connections" 错误 之 mysql解决方法

编程语言 网络编程
mysql "too many connections" 错误 之 mysql解决方法

远离"过劳死"小常识

生活常识 养生 健康
远离"过劳死"小常识

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

Dreamweaver4简明教程(八、为网页增添互动效果3)

Dreamweaver4简明教程(八、为网页增添互动效果3)

DreamWeaver,经典50问(七)

DreamWeaver,经典50问(七)
下拉加载更多内容 ↓