HaProxy+keepalived+mycat集群高可用配置

部署图


集群部署图的理解:

1、keepalived和haproxy必须装在同一台机器上(如172.17.210.210.83机器上,keepalived和haproxy都要安装),keepalived负责为该服务器抢占vip(虚拟ip),抢占到vip后,对该主机的访问可以通过原来的ip(172.17.210.210.83)访问,也可以直接通过vip(172.17.210.210.103)访问。

2、172.17.210.64上的keepalived也会去抢占vip,抢占vip时有优先级,配置keepalived.conf中的(priority 150 #数值愈大,优先级越高,172.17.210.64上改为120,master和slave上该值配置不同)决    定。但是一般哪台主机上的keepalived服务先启动就会抢占到vip,即使是slave,只要先启动也能抢到。

3、haproxy负责将对vip的请求分发到mycat上。起到负载均衡的作用,同时haproxy也能检测到mycat是否存活,haproxy只会将请求转发到存活的mycat上。

4、如果一台服务器(keepalived+haproxy服务器)宕机,另外一台上的keepalived会立刻抢占vip并接管服务。

     如果一台mycat服务器宕机,haporxy转发时不会转发到宕机的mycat上,所以mycat依然可用。

Haproxy安装

haproxy安装
useradd haproxy
 
# tar zxvf haproxy-1.4.25.tar.gz
# cd haproxy-1.4.25
# make TARGET=linux26 PREFIX=/usr/local/haproxy ARCH=x86_64
# make install PREFIX=/usr/local/haproxy
 
#cd /usr/local/haproxy
#chown -R haproxy.haproxy *

haproxy.cfg

haproxy.cfg
#cd /usr/local/haproxy
#touch haproxy.cfg
#vi/usr/local/haproxy/haproxy.cfg
global
log 127.0.0.1   local0  ##记日志的功能
     maxconn 4096
     chroot /usr/local/haproxy
     user haproxy
     group haproxy
     daemon
defaults
     log    global
     option    dontlognull
     retries    3
     option redispatch
     maxconn    2000
     contimeout    5000
     clitimeout    50000
     srvtimeout    50000
listen  admin_status 172.17.210.103:48800  ##VIP
       stats uri /admin-status        ##统计页面
       stats auth  admin:admin
       mode    http
       option  httplog
listen    allmycat_service 172.17.210.103:8096  ##转发到mycat的8066端口,即mycat的服务端口
       mode tcp
       option tcplog
         option httpchk OPTIONS * HTTP /1 .1\r\nHost:\ www
       balance    roundrobin
         server    mycat_133 172.17.210.133:8066 check port 48700 inter 5s rise 2 fall 3
         server    mycat_134 172.17.210.134:8066 check port 48700 inter 5s rise 2 fall 3
       srvtimeout 20000
listen    allmycat_admin 172.17.210.103:8097  ##转发到mycat的9066端口,及mycat的管理控制台端口
       mode tcp
       option tcplog
         option httpchk OPTIONS * HTTP /1 .1\r\nHost:\ www
       balance    roundrobin
         server    mycat_133 172.17.210.133:9066 check port 48700 inter 5s rise 2 fall 3
         server    mycat_83  172.17.210.134:9066 check port 48700 inter 5s rise 2 fall 3
       srvtimeout 20000

haproxy记录日志

默认haproxy是不记录日志的,为了记录日志还需要配置syslog模块,在linux下是rsyslogd服务,yum –y install rsyslog先安装rsyslog,然后

记录haproxy日志的配置
#cd /etc/rsyslog.d/
如果没有这个目录,新建
#cd /etc
#mkdir rsyslog.d
#cd /etc/rsyslog.d/
#touch haproxy.conf
#vi /etc/rsyslog.d/haproxy.conf
$ModLoad imudp
$UDPServerRun 514
 
local0.* /var/log/haproxy .log
 
 
 
#vi /etc/rsyslog.conf
  • 2
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 7
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值