负载均衡集群介绍,Server的AlwaysOn辅助别本

图片 31
数据库

采纳HAProxy代理SQL Server的AlwaysOn帮忙别本

供销合作社前段时间数据库升级到SQL Server二零一四 ,并安排了alwayson高可用集群

机室内有三套程序须要读取数据库

首先套:主程序,读写数据库,连接主别本

其次套:报表程序,读报表,连接协助别本

其三套:历史库程序,读历史库,连接援助别本

 

软件条件

图片 1

机器情形

图片 2

 

架构图

图片 3

为什麽须要使用HAProxy?

前边机房里面有三千个顶峰,这几个极端是二个非常小的嵌入式设备,第二套报表程序原本是行使直连数据库IP(10.11.10.36)来连接数据库

但如此有一个弊病,当36那台帮忙副本宕机,那么报表程序就瘫痪了,因为三千个顶峰要转移数据库连接需求烧写程序到巅峰里面极其耗时

莫不要几天时间

 

终极决定利用HAProxy做负载均衡和TCP连接重定向

动用HAProxy有多少个好处

1、前端没有须求后端数据库的实在IP,当要求升高后端数据库,比方打补丁的时候特别方便

2、HAProxy能够自动检查评定后端数据库服务,探测1433端口是否存活,假设1433端口出难题,能够自行重定向连接到37那台支持别本

3、缓解单台读库压力,使用Sportage逍铁船询算法,央求均衡分发到36和37这两台帮忙别本,缓慢消除36那台机器的下压力

图片 4

 

 


HAProxy相关配置步骤

 

#yum安装,版本是1.5.4

yum install -y haproxy.x86_64

 

 

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

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

 

 

#编排rsyslog.conf 文件增添两行local3.*  和local0.*

vi /etc/rsyslog.conf
local7.*                                                /var/log/boot.log
local3.*                                                /var/log/haproxy.log
local0.*                                               /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     
stats socket /var/run/haproxy.sock mode 666 level admin
stats timeout 2m


defaults 
mode http 
log                 127.0.0.1:514       local3                     
option                  dontlognull
#option http-server-close
#option forwardfor       except 127.0.0.0/8
option 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 *:2080
stats enable
stats refresh 30s
stats uri /haproxyadminstats
stats realm HAProxy\ Statistics
stats auth admin:admin
stats admin if TRUE


listen mssql :1433
mode tcp
balance roundrobin
server mssqldb1 10.11.10.36:1433 weight 1 maxconn 6000 check port 1433 inter 2000 rise 2 fall 2
server 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机器只须要选拔三个网口,没有要求极其扩大网口

图片 5

#打开后台管理界面

 

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

图片 6

 

查看haproxy的日志

cat /var/log/haproxy.log

图片 7


测量试验申明

使用SSMS2016来连接HAProxy的IP

10.11.10.39

图片 8

当今是三番两次到GZC-SQL03那台机

 

今天把 GZC-SQL03那台机的SQL服务停了

图片 9

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

图片 10

 再度点击一下实施开关,能够发掘已经重定向到 GZC-SQL02那台机

图片 11

 

 

即使如此经过HAProxy这一层,然而质量方面也不算太差

图片 12


 

HAProxy的通讯格局

通讯方式接近于LVS的NAT情势

LVS的NAT格局(调整器将诉求的目的ip即vip地址改为Real server的ip,
重返的数目包也透过调解器,调节器再把源地址修改为vip)

图片 13

图片 14

 

 


总结

线上景况使用HAProxy已经大半1个月,到今天从不出现过难题,比较牢固

对于HAProxy原理上的东西这里就不陈说了,英特网有好些个资料

 

参照小说:

 

假若是各样业务应用差异端口,能够行使上面包车型大巴计划文件

比方报表使用1433端口,BI收取数据利用2433端口

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 
    stats socket /var/run/haproxy.sock mode 666 level admin
    stats timeout 2m




defaults         
    mode                    http               
    log                     global                         
    option                  dontlognull
    option http-server-close
    option forwardfor       except 127.0.0.0/8
    option                  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 *:2080
    stats enable
    stats refresh 30s
    stats uri   /haproxyadminstats
    stats realm  HAProxy\ Statistics
    stats auth   admin:admin
    stats admin if TRUE


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


listen mssql2 :2433
    mode tcp
    balance leastconn
    server mssqldb3 10.11.10.37:1433   maxconn 6000 check port 1433 inter 2000  rise 2 fall 2

 

 

如有不对的地点,迎接我们拍砖o(∩_∩)o 

本文版权归小编全体,未经作者同意不得转发。

负载均衡集群介绍

  • 主流开源软件LVS、keepalived、haproxy、nginx等
  • 内部LVS属于4层(互连网OSI
    7层模型),nginx属于7层,haproxy不只能够以为是4层,也得以当作7层使用
  • keepalived的载重均衡功效实在正是lvs
  • lvs这种4层的负荷均衡是能够分发TCP左券,web服务是80端口,除了分发80端口,还只怕有别的的端口通讯的,举例MySQL的载重均衡,就足以用LVS达成,而nginx仅仅帮衬http,https,mail,haproxy;haproxy也支撑MySQL这种TCP负载均衡的
  • 相相比的话,LVS这种4层的更安宁,能承受更加多的乞请,承载的并发量越来越高,而nginx这种7层的更为灵活,能兑现更加多的个性化必要

LVS介绍

  • LVS是由国人章文嵩开垦
  • 流行度不亚于apache的httpd,基于TCP/IP做的路由和转账,稳固性和频率异常高
  • LVS最新版本基于Linux内核2.6,有众多年不创新了
  • LVS有二种广泛的情势:NAT、DLacrosse、IP Tunnel
  • LVS框架结构中有贰个为主演色叫做分发器(Load
    balance),它用来散发客商的乞请,还也有比比较多甩卖客户恳求的服务器(Real
    Server,简称rs)

LVS NAT模式

图片 15

  • 依傍iptables的nat表来完结
  • 顾客的呼吁到分发器后,通过预设的iptables法规,把须要的多寡包转载到后端的rs上去
  • rs要求设定网关为分发器的内网ip
  • 客户央求的数据包和再次回到给客户的多少包全部透过分发器,所以分发器成为瓶颈
  • 在nat方式中,只供给分发器有公网ip就可以,所以相比节省公网ip能源

LVS IP Tunnel模式

图片 16

  • 这种格局,要求有一个共用的IP配置在分发器和全部rs上,大家把它叫做vip
  • 顾客端央求的对象IP为vip,分发器接收到哀告数据包后,会对数据包做一个加工,会把目标IP改为rs的IP,那样数据包就到了rs上
  • rs接收数据包后,会上升原始数据包,那样目的IP为vip,因为有着rs上配备了这一个vip,所以它会感到是它本身

LVS DR模式

图片 17

  • 这种方式,也急需有四个公家的IP配置在分发器和颇具rs上,也正是vip
  • 和IP Tunnel分歧的是,它会把数据包的MAC地址修改为rs的MAC地址
  • rs接收数据包后,会还原原始数据包,那样指标IP为vip,因为具有rs上配置了那些vip,所以它会认为是它自个儿

LVS调整算法

  • 轮询 Round-Robin rr
  • 加权轮询 Weight Round-罗布in wrr
  • 细微连接 Least-Connection lc
  • 加权最小连接 Weight Least-Connection wlc
  • 依附局地性的纤维连接 Locality-Based Least Connections lblc
  • 带复制的依据局地性最小连接 Locality-Based Least Connections with
    Replication lblcr
  • 对象地点散列调治 Destination Hashing dh
  • 源地址散列调节 Source Hashing sh

常用的算法是前种种

LVS NAT形式搭建

希图职业

  • 三台机器
  • 分发器,也叫调治器(简写为dir)
  • 内网:133.130,外网:142.147(vmware仅主机形式)
  • rs1
  • 内网:133.132,设置网关为133.130
  • rs2
  • 内网:133.133,设置网关为133.130
  • 三台机器上都试行推行
  • systemctl stop firewalld; systemc disable firewalld
  • systemctl start iptables-services; iptables -F; service iptables
    save

NAT方式搭建

  • 在dir上安装ipvsadm
  • yum install -y ipvsdam
  • 在dir上编写制定脚本,vim /usr/local/sbin/lvs_nat.sh//内容如下

#! /bin/bash
# director 服务器上开启路由转发功能
echo 1 > /proc/sys/net/ipv4/ip_forward
# 关闭icmp的重定向
echo 0 > /proc/sys/net/ipv4/conf/all/send_redirects
echo 0 > /proc/sys/net/ipv4/conf/default/send_redirects
# 注意区分网卡名字,阿铭的两个网卡分别为ens33和ens37
echo 0 > /proc/sys/net/ipv4/conf/ens33/send_redirects
echo 0 > /proc/sys/net/ipv4/conf/ens37/send_redirects
# director 设置nat防火墙
iptables -t nat -F
iptables -t nat -X
iptables -t nat -A POSTROUTING -s 192.168.133.0/24  -j MASQUERADE
# director设置ipvsadm
IPVSADM='/usr/sbin/ipvsadm'
$IPVSADM -C
$IPVSADM -A -t 192.168.147.144:80 -s wlc -p 3
$IPVSADM -a -t 192.168.147.144:80 -r 192.168.133.132:80 -m -w 1
$IPVSADM -a -t 192.168.147.144:80 -r 192.168.133.133:80 -m -w 1

NAT格局功能测量试验

  • 两台rs上都安装nginx
  • 设置两台rs的主页,做一个有别于,约等于说直接curl两台rs的ip时,得到分化的结果
  • 浏览器里拜访192.168.142.147,多访谈五遍看结果差距

希图三台机器,一台作为分发器(内网:133.130,外网:142.147),其余两台是real
server,分别为rs1(内网:133.132,网关为133.130)和rs2(内网:133.133,网关为133.130)

分发器扩展一块网卡,查看网卡网段,所以设置IP192.168.142.147

图片 18

图片 19

图片 20

接下来查看是不是ping通

图片 21

三台机器配置好了今后,全部索要关闭防火墙

图片 22

然后在rs1,rs2上安装iptables-services包,启动iptables服务

图片 23

 systemctl start iptables
 systemctl enable iptables

接下来调用新准则,防止私下认可准则影响实验效果;最终关闭selinux,最棒修改下布署文件

图片 24

图片 25

图片 26

安装ipvsadm工具

图片 27

然后编写脚本,vim
/usr/local/sbin/lvs_nat.sh,保存退出;然后实行该脚本sh
/usr/local/sbin/lvs_nat.sh,脚本无输出表示无不当

图片 28

$IPVSADM -A -t 192.168.147.144:80 -s rr -p 3
#-A:=add,加多准则;-t:=tcp;-s 钦命算法; -p:内定超时时间

在rs1和rs2上安装nginx,并分别修改主页内容

图片 29

图片 30

然后能够做测量检验,如下表示测量试验成功

图片 31

扩展

lvs 三种情势详解

lvs三种算法

关于arp_ignore和
arp_announce

lvs原理相关的

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图