利用HAProxy代理SQL Server的AlwaysOn辅助副本

Posted SQLServer走起

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了利用HAProxy代理SQL Server的AlwaysOn辅助副本相关的知识,希望对你有一定的参考价值。

公司最近数据库升级到SQL Server2014 ,并部署了alwayson高可用集群

机房内有三套程序需要读取数据库

第一套:主程序,读写数据库,连接主副本

第二套:报表程序,读报表,连接辅助副本

第三套:历史库程序,读历史库,连接辅助副本

 

软件环境

机器环境

利用HAProxy代理SQL Server的AlwaysOn辅助副本

 

架构图

利用HAProxy代理SQL Server的AlwaysOn辅助副本

为什麽需要使用HAProxy?

之前机房里面有2000个终端,这些终端是一个很小的嵌入式设备,第二套报表程序原来是使用直连数据库IP(10.11.10.36)来连接数据库

但这样有一个弊端,当36这台辅助副本宕机,那么报表程序就瘫痪了,因为2000个终端要更改数据库连接需要烧写程序到终端里面非常耗费时间

可能要几天时间

 

最后决定使用HAProxy做负载均衡和TCP连接重定向

使用HAProxy有几个好处

1、前端不需要后端数据库的实际IP,当需要升级后端数据库,比如打补丁的时候特别方便

2、HAProxy能够自动检测后端数据库服务,探测1433端口是否存活,如果1433端口出问题,能够自动重定向连接到37这台辅助副本

3、减轻单台读库压力,使用RR轮询算法,请求均衡分发到36和37这两台辅助副本,减轻36这台机器的压力

利用HAProxy代理SQL Server的AlwaysOn辅助副本

 

 


HAProxy相关配置步骤

 

#yum安装,版本是1.5.4

yum install -y haproxy.x86_64

 

 

#编辑rsyslog 文件,修改为-c 2 -r

vi /etc/sysconfig/rsyslog
SYSLOGD_OPTIONS="-c 2 -r"

 


#编辑rsyslog.conf 文件添加一行local2.*

vi /etc/rsyslog.conf
local7.* /var/log/boot.log

local2.* /var/log/haproxy.log

 

#重启rsyslog服务

service rsyslog restart

 

 


# 编辑haproxy配置文件 下面以mssql从库负载均衡为例

vi /etc/haproxy/haproxy.cfg

global
log 127.0.0.1 local2 
chroot /var/lib/haproxy 
pidfile /var/run/haproxy.pid 
maxconn 6000 user haproxy 
group haproxy 
daemon 
stats socket /var/lib/haproxy/stats


defaults 
mode http 
log global 
option dontlognull
option http-server-close
option forwardfor except 127.0.0.0/8option redispatch
retries 3 timeout http-request 10s 
timeout connect 10s 
timeout client 1m 
timeout server 1m 
timeout http-keep-alive 10s
timeout check 10s
maxconn 6000

 

 listen stats 
mode http
bind *:2080stats enable
stats refresh 30s
stats uri /haproxyadminstats
stats realm HAProxy\ Statistics
stats auth admin:admin
stats admin if TRUE


listen mssql :1433mode tcp
balance roundrobin
server mssqldb1 10.11.10.36:1433 weight 1 maxconn 6000 check port 1433 inter 2000 rise 2 fall 2server mssqldb2 10.11.10.37:1433 weight 1 maxconn 6000 check port 1433 inter 2000 rise 2 fall 2

 




#检查配置文件是否有语法错误

haproxy -f /etc/haproxy/haproxy.cfg -c
Configuration file is valid

 


#启动haproxy

/etc/init.d/haproxy start

 

 

#检查haproxy是否在监听

netstat -lntp

 

注意:Centos机器只需要使用一个网口,不需要额外增加网口

利用HAProxy代理SQL Server的AlwaysOn辅助副本


#打开后台管理界面
http://10.11.30.47:2080/haproxyadminstats

 

HAProxy提供了一个后台管理界面

利用HAProxy代理SQL Server的AlwaysOn辅助副本

 

 


测试验证

使用SSMS2016来连接HAProxy的IP

10.11.10.39

利用HAProxy代理SQL Server的AlwaysOn辅助副本

现在是连接到GZC-SQL03这台机

 

现在把 GZC-SQL03这台机的SQL服务停了

利用HAProxy代理SQL Server的AlwaysOn辅助副本

HAProxy已经探测到 GZC-SQL03这台机的SQL服务停了

利用HAProxy代理SQL Server的AlwaysOn辅助副本

 再次点击一下执行按钮,可以发现已经重定向到 GZC-SQL02这台机

利用HAProxy代理SQL Server的AlwaysOn辅助副本

 

 

虽然经过HAProxy这一层,但是性能方面也不算太差

利用HAProxy代理SQL Server的AlwaysOn辅助副本


 

HAProxy的通信方式

通信方式类似于LVS的NAT模式

利用HAProxy代理SQL Server的AlwaysOn辅助副本

利用HAProxy代理SQL Server的AlwaysOn辅助副本

 

 


总结

线上环境使用HAProxy已经差不多1个月,到现在没有出现过问题,比较稳定

对于HAProxy原理上的东西这里就不叙述了,网上有很多资料


文章出处:http://www.cnblogs.com/lyhabc/p/5820492.html

文章经作者授权转载



微信公众号能置顶啦,喜欢我的小伙伴们请将我置顶吧,这样就不用担心找不到我了哦~

以上是关于利用HAProxy代理SQL Server的AlwaysOn辅助副本的主要内容,如果未能解决你的问题,请参考以下文章

如何利用HAProxy 代理 MySQL Master-Slave Replication

如何利用HAProxy 代理 MySQL Master-Slave Replication

Nginxnginx 代理 Haproxy 怎么设置?

33-haproxy

SQL SERVER 2008复制数据库时发生执行SQL Server代理作业错误

HaProxy 实现443 端口复用