Keepalived+Haproxy实现高可用负载均衡

高可用负载(主备节点)部署步骤

完成下图一个简单的高可用负载机制:

这里写图片描述

1.拷贝keepalived-1.2.19.tar.gz至Linux的/home目录(也可以是其它目录)

2.解压并安装keepalived:

tar -zxvf keepalived-1.2.19.tar.gz
yum install popt-devel
yum -y install openssl-devel
cd keepalived-1.2.19
./configure
make && make install

这样keepalived编译及安装完成!

3.拷贝并复制keepalived:

cp /usr/local/etc/rc.d/init.d/keepalived /etc/rc.d/init.d/
cp /usr/local/etc/sysconfig/keepalived /etc/sysconfig/
mkdir /etc/keepalived
cp /usr/local/etc/keepalived/keepalived.conf /etc/keepalived/
cp /usr/local/sbin/keepalived /usr/sbin/

上传并覆盖keepalived.conf至/etc/keepalived
备注:keepalived.conf详见步骤4

上传check_haproxy.sh至/etc/keepalived
备注:check_haproxy.sh配置文件内容如下:

#!/bin/bash
A=`ps -C haproxy --no-header |wc -l`
if [ $A -eq 0 ];then
/usr/local/haproxy/sbin/haproxy -f /usr/local/haproxy/cfg/haproxy.cfg
sleep 3
if [ `ps -C haproxy --no-header |wc -l` -eq 0 ];then
/etc/init.d/keepalived stop
fi
fi

4.修改keepalived.conf配置文件:

! Configuration File for keepalived

global_defs {
   notification_email {
        receiver@qq.com  #  修改成可用的收件人地址,可为多个
   }
 notification_email_from sender@qq.com  #  修改成可用的发件人地址
   smtp_server mail.iflytek.com  #  修改成可用的邮箱代理地址
   smtp_connect_timeout 30
   router_id keepalived
}
vrrp_script chk_http_port {
     script "/etc/keepalived/check_haproxy.sh"   #  修改成Haproxy监控脚本路径
     interval 2   #  检查间隔时间,单位:秒
}
vrrp_instance VI_MASTER {
    state MASTER  #  修改成MASTER,意味着该服务器为主节点;若修改为BACKUP,则为备用节点,即当主机宕掉,从机接管
    interface eth0
    virtual_router_id 51
    priority 150
    nopreempt
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    track_script {
             chk_http_port
    }
    virtual_ipaddress {
        192.168.1.1  #  修改成可用的虚拟IP
    }
}

5.解压haproxy-1.5.12并上传至/usr/local

6.修改/usr/local/haproxy/cfg配置文件haproxy.cfg:

global
      daemon
      nbproc 1
      group nobody
      user nobody
      maxconn 102400
      ulimit-n 204821
      chroot /usr/local/haproxy

defaults
      mode tcp
      maxconn 102400
      retries 3
      option redispatch
      option abortonclose
      timeout connect 600s
      timeout client 600s
      timeout server 600s

listen interface
      bind 0.0.0.0:8001
      balance leastconn
      mode http
      server interface1 192.168.85.100:8001 weight 1 maxconn 102400 check inter 10s
      server interface2 192.168.85.101:8001 weight 1 maxconn 102400 check inter 10s

listen engine
      bind 0.0.0.0:18006
      balance leastconn
      mode tcp
      server engine1 192.168.85.100:18006 weight 1 maxconn 102400 check inter 10s
      server engine2 192.168.85.101:18006 weight 1 maxconn 102400 check inter 10s

至此完成Haproxy配置修改!

7.运行如下命令,启动Haproxy运行:

/etc/init.d/keepalived start

8.测试:

telnet 192.168.1.1 8001
telnet 192.168.1.1 18006

依次使用虚拟IP+路由端口的形式验证对应端口是否可用!

说明:对于从机部署,与主机部署一致。这里说明一下:对于HA,只会使用主节点,仅当主节点挂掉,才会切换到从节点!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值