视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
如何使用"MySQL-Proxy"实现读写分离[_MySQL
2020-11-09 17:48:45 责编:小采
文档


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

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

  ?查询分析和日志

  ?SQL宏(SQL macros)

  ?查询重写(query rewriting)

  ?执行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)。

下载本文
显示全文
专题