设为首页 收藏本站
查看: 1743|回复: 0

[经验分享] HAProxy+Keepalived实现双主高可用负载均衡

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-10-19 09:16:36 | 显示全部楼层 |阅读模式
一、规划

      
1
2
3
4
5
6
7
                  OS:CentOS7
HAProxy+Keepalived-1:192.168.10.128
HAProxy+Keepalived-2:192.168.10.129
                VIP1:192.168.10.111
                VIP2:192.168.10.222
                WEB1:192.168.10.130:80
                WEB2:192.168.10.131:80




二、配置Keepalived(注:安装及配置解释详见本博其他文章)


①配置keepalived主配置文件(配置文件大部相同)
      配置192.168.10.128做192.168.10.111的MASTER,192.168.10.222的BACKUP;
      配置192.168.10.128做192.168.10.111的BACKUP,192.168.10.222的MASTER.


a.192.168.10.128配置如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
# vi /etc/keepalived/keepalived.conf
! Configuration File for keepalived
global_defs {
   notification_email {
        root@localhost
        zhi@163.com                   ##设置邮件报警地址
   }
   notification_email_from zhi@zhi.com
   smtp_server 127.0.0.1
   smtp_connect_timeout 3
   router_id LVS_DEVEL
}
vrrp_script check_haproxy {                      ##添加haproxy服务监控脚本
      script "/etc/keepalived/check_haproxy.sh"  
      interval 2
      weight 2
}
vrrp_instance VI_1 {                         ##配置vrrp实例1
    state MASTER                     
    interface eno16777736
    virtual_router_id 51               ##实例1虚拟路由标识
    priority 101                     
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
track_script {                                 ##检测执行脚本
     check_haproxy
}
    virtual_ipaddress {
        192.168.10.111
    }
}
vrrp_instance VI_2 {                      ##配置vrrp实例2
    state BACKUP                        
    interface eno16777736
    virtual_router_id 52                 ##实例2虚拟路由标识
    priority 100                          
    advert_int 1
    garp_master_delay 5
    authentication {
        auth_type PASS
        auth_pass 1111
    }

virtual_ipaddress {
        192.168.10.222
    }




b.192.168.10.129配置如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
# vi /etc/keepalived/keepalived.conf
! Configuration File for keepalived
global_defs {
   notification_email {
        root@localhost
        zhi@163.com                   ##设置邮件报警地址
   }
   notification_email_from zhi@zhi.com
   smtp_server 127.0.0.1
   smtp_connect_timeout 3
   router_id LVS_DEVEL
}
vrrp_script check_haproxy {                      ##添加haproxy服务监控脚本
      script "/etc/keepalived/check_haproxy.sh"  
      interval 2
      weight 2
}
vrrp_instance VI_1 {                         ##配置vrrp实例1
    state BACKUP
    interface eno16777736
    virtual_router_id 51                     ##实例1虚拟路由标识
    priority 100
    advert_int 1
    garp_master_delay 5
    authentication {
        auth_type PASS
        auth_pass 1111
    }

track_script {                           ##检测执行脚本
     check_haproxy
}
virtual_ipaddress {
        192.168.10.111
    }

}
vrrp_instance VI_2 {                       ##配置vrrp实例2
    state MASTER
    interface eno16777736
    virtual_router_id 52                   ##实例2虚拟路由标识
    priority 101
    advert_int 1
    garp_master_delay 5
    authentication {
        auth_type PASS
        auth_pass 1111
    }

virtual_ipaddress {
        192.168.10.222
    }





②配置HAProxy检测脚本

1
2
3
4
5
6
7
8
9
10
11
12
# vi /etc/keepalived/check_haproxy.sh
#!/bin/bash
if [ $(ps -C haproxy --no-header |wc -l) -eq 0 ]
then
    systemctl start haproxy
fi
sleep 2
if [ $(ps -C haproxy --no-header |wc -l) -eq 0 ]
then
    systemctl stop keepalived
fi
# chmod u+x /etc/keepalived/check_haproxy.sh




③开启keepalived并查看
1
# systemctl start keepalived





192.168.10.128:

wKiom1YgokTSS74LAAIZJbXVKr4000.jpg
192.168.10.129:
wKiom1YgouqQglk0AAI3K-xTCuQ067.jpg



三、配置HAProxy(注:安装及配置解释详见本博其他文章)
①配置HAProxy主配置文件(配置文件相同)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
# vi /etc/haproxy/haproxy.cfg
# this config needs haproxy-1.1.28 or haproxy-1.2.1
global                                               ##全局配置
        log 127.0.0.1   local0
        log 127.0.0.1   local1 notice
        #log loghost    local0 info
        maxconn 4096
        chroot /usr/share/haproxy
        uid 99
        gid 99
        daemon
        #debug
        #quiet
defaults                                             ##默认配置
        log     global
        mode    http
        option  httplog
        option  dontlognull
        retries 3
        option redispatch
        maxconn 4000
        timeout connect 5000
        timeout client  50000
        timeout server  50000
frontend web                                                  ##前端代理
       bind 0.0.0.0:80
       acl www.zhi.com hdr(host) -i      
       use_backend www.zhi.com if www.zhi.com
       acl www.fly.com hdr(host) -i www.fly.com
       use_backend www.fly.com if  
backend                     ##后端www.zhi.com作用域
        mode http
        balance source               ##保存session值
        option  httpchk /index.html
        server  192.168.10.130 192.168.10.130:80 check inter 2000 rise 2 fall 1
backend                    ##后端www.fly.com作用域  
        mode http
        balance source                 ##保存session值
        option  httpchk /index.html
        server  192.168.10.131 192.168.10.131:80 check inter 2000 rise 2 fall 1
listen status                           ##监控页面设置
        mode http
        bind 0.0.0.0:80
        stats enable
        stats hide-version
        stats uri     /haproxyadmin
        stats auth    admin:admin
        stats admin if TRUE




②开启HAProxy并查看
1
# systemctl start haproxy



①浏览器输入192.168.10.128/haproxyadmin,输入账号密码查看
wKiom1Ygqi6S_SGMAAjXpJTlBiE807.jpg
②浏览器输入192.168.10.129/haproxyadmin,输入账号密码查看
wKioL1YgqqOBI8OeAAjk9oiqM7s591.jpg
③浏览器输入192.168.10.111/haproxyadmin,输入账号密码查看
wKiom1Ygqqvg3bz1AAjWQhY6Ifg454.jpg
④浏览器输入192.168.10.222/haproxyadmin,输入账号密码查看
wKioL1YgqveS0PtwAAi5-NsL-H8126.jpg



四、测试


①更改Windows的hosts文件
1
2
3
4
5
C:\Windows\System32\drivers\etc\hosts
192.168.10.111     www.zhi.com
192.168.10.111     www.zhi.com
192.168.10.222     www.fly.com
192.168.10.222     www.fly.com





②测试1
ping www.zhi.com
wKiom1YgrlXQ5s-aAAFgNXgV8o4664.jpg

ping www.fly.com
wKiom1YgrpSyKL1uAAFKlPgHUe8545.jpg

③测试2
192.168.10.128:
1
2
# systemctl stop keepalived
# ip addr



wKioL1Ygr6DAdCLHAAH8O4WN8Zg328.jpg
192.168.10.129:
# ip addr
wKiom1Ygr-WQNlldAAJmQZIKcRM741.jpg
虚拟IP192.168.10.111已漂移至192.168.10.129,继续ping,依然通
wKioL1YgsHXSUaLKAAHBrRleq84587.jpg
OK了

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-128528-1-1.html 上篇帖子: HAProxy的编译安装配置 下篇帖子: Haproxy在大并发下的表现
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表