首页 > 解决方案 > 使用 HAproxy 拆分 mysql 集群的读/写

问题描述

我在 ubuntu 16.04 上有一个 mysql 集群,想用 haproxy 拆分读/写。

所有连接都将通过端口 80 完成。如果有人使用 XXXX/write 连接到服务器,我希望他被重定向到 1 个特定服务器。到目前为止,这是我的配置,它适用于默认值(除 /write 之外的任何内容),但是当尝试与 /write 连接时,我得到“未知的 MySql 服务器主机”。我的配置如下:

global
log 127.0.0.1 local0 notice
maxconn 2000
user haproxy
group haproxy

defaults
mode tcp
log global
retries 2
timeout connect 3000
timeout server 5000
timeout client 5000

backend read
balance roundrobin
server mysql1 192.168.0.4:3306
server mysql2 192.168.0.5:3306
server mysql3 192.168.0.6:3306

backend write
server mysql1 192.168.0.4:3306

frontend local
bind *:80
acl write url_beg /write
use_backend write if write
default_backend read

谢谢您的帮助!

标签: mysqlubuntureverse-proxyhaproxyportforwarding

解决方案


MySQL 连接中没有“URL”,因此url_beg不可能匹配任何内容。连接到 MySQL 服务器(或代理)仅通过 IP 地址或主机名完成——不是主机名和路径,因为没有路径。检测客户端使用的主机名是不可能的,因为建立连接时没有通过。

为了完成你想要的,你需要两个不同的主机名,指向 HAProxy 服务器上的两个不同的 IP 地址,并且这两个 IP 中的每一个都在它自己的单独frontend的 withbind语句中。

frontend read
  mode tcp
  bind 203.0.113.1:3306
  default_backend read

frontend write
  mode tcp
  bind 203.0.113.2:3306
  default_backend write

推荐阅读