使用HAproxy为阿里中间件做负载均衡。

本文涉及的产品
云原生网关 MSE Higress,422元/月
性能测试 PTS,5000VUM额度
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: 在内部系统不是非常的高并发,大流量的场景下,且有windows,Linux混合操作系统场景下,便于配置维护,可以使用HApoxy 替代 LVS一试。


背景:
   最近为一传统行业客户部署阿里中间件的过程中,需要使用负载均衡技术,最初计划使用LVS的DR模式,但考虑到使用LVS DR+keepalived模式 配置较为复杂,服务器数量较多,需要在后端服务器上做VIP绑定和ARP抑制操作,后期维护困难,还有windows系统,而且用户对Linux系统不熟悉。后来准备使用LVS的NAT模式,因为NAT模式不需要对后端服务器做修改,可是NAT模式对网络结构有要求,我们不能改变用户的网络结构。于是使用了HAproxy的反向代理功能。与keepalived做高可用使用了负载的功能。

1 安装HAproxy
yum install haproxy –y 
rpm -ql haproxy
/etc/haproxy
/etc/haproxy/haproxy.cfg
/etc/logrotate.d/haproxy
/etc/rc.d/init.d/haproxy
/usr/bin/halog
/usr/sbin/haproxy

2  HAproxy主要配置
#---------------------------------------------------------------------
# main frontend which proxys to the backends
#---------------------------------------------------------------------
frontend address
    bind 10.6.68.200:8080
    mode tcp
    default_backend   address-rs
frontend diamond 
    bind 10.6.68.201:8080
    mode tcp
    default_backend   diamond-rs
frontend dauth-80
    bind 10.6.68.202:80
    mode tcp
    default_backend   dauth-80-rs
frontend dauth-443
    bind 10.6.68.202:443
    mode tcp
    default_backend   dauth-443-rs
    ………………
    ………………
#---------------------------------------------------------------------
# static backend for serving up images, stylesheets and such
#---------------------------------------------------------------------
backend address-rs
    balance     roundrobin
    server      server 10.6.68.101:8080 check
    server      server 10.6.68.102:8080 check
backend diamond-rs
    balance     roundrobin
    server      server 10.6.68.126:8080 check
    server      server 10.6.68.127:8080 check
    server      server 10.6.68.128:8080 check
backend dauth-80-rs
    balance     roundrobin
    server      server 10.6.68.124:80 check
    server      server 10.6.68.125:80 check
backend dauth-443-rs
    balance     roundrobin
    server      server 10.6.68.124:443 check
    server      server 10.6.68.125:443 check
    ……………………
    ……………………

3 keepalived 配置
[root@haproxy01 keepalived]# cat keepalived.conf 
! Configuration File for keepalived

global_defs {
   notification_email {
   }
   router_id HAproxy01
}



vrrp_script chk_http_port {
                script "/etc/keepalived/check_haproxy.sh"
                interval 2
                weight 2
}




vrrp_instance VI_1 {
    state MASTER
    interface eth0
    virtual_router_id 51
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass ……
    }
track_script { 
        chk_http_port 
        }

    virtual_ipaddress {
        10.6.68.200
        10.6.68.201
        10.6.68.202
        …………
        …………
    }
}

[root@haproxy 02 keepalived]# cat keepalived.conf 
! Configuration File for keepalived
global_defs {
   }
   router_id HAproxy02
}
vrrp_script chk_http_port {
                script "/etc/keepalived/check_haproxy.sh"
                interval 2
                weight 2
}

vrrp_instance VI_1 {
    state BACKUP
    interface eth0
    virtual_router_id 51
    priority 90
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass ……
    }
 track_script { 
        chk_http_port 
    }

    virtual_ipaddress {
        10.6.68.200/24
        10.6.68.201/24
        10.6.68.202/24
        ………
        ………
   
    }
}

4 haproxy的检测脚本--判断haproxy是否是存活的。
vim  check_haproxy.sh 
#!/bin/bash
if [ $(ps -C haproxy --no-header | wc -l) -eq 0 ]; then
     /etc/init.d/haproxy  restart &>/dev/null
fi

sleep 2

相关实践学习
SLB负载均衡实践
本场景通过使用阿里云负载均衡 SLB 以及对负载均衡 SLB 后端服务器 ECS 的权重进行修改,快速解决服务器响应速度慢的问题
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
目录
相关文章
|
6月前
|
负载均衡 中间件 应用服务中间件
中间件负载均衡
【7月更文挑战第21天】
256 6
|
1月前
|
存储 NoSQL 架构师
阿里面试:聊聊 CAP 定理?哪些中间件是AP?为什么?
本文深入探讨了分布式系统中的“不可能三角”——CAP定理,即一致性(C)、可用性(A)和分区容错性(P)三者无法兼得。通过实例分析了不同场景下如何权衡CAP,并介绍了几种典型分布式中间件的CAP策略,强调了理解CAP定理对于架构设计的重要性。
87 4
|
1月前
|
负载均衡 前端开发 应用服务中间件
负载均衡指南:Nginx与HAProxy的配置与优化
负载均衡指南:Nginx与HAProxy的配置与优化
106 3
|
3月前
|
负载均衡 Kubernetes 区块链
随机密码生成器+阿里k8s负载均衡型服务加证书方法+移动终端设计+ico生成器等
随机密码生成器+阿里k8s负载均衡型服务加证书方法+移动终端设计+ico生成器等
78 1
|
5月前
|
负载均衡 算法 前端开发
HAProxy 和负载均衡概念简介
HAProxy 和负载均衡概念简介
104 3
|
6月前
|
负载均衡 监控 算法
|
7月前
|
消息中间件 存储 NoSQL
阿里开源中间件一览
阿里开源中间件一览
494 2
|
8月前
|
负载均衡 算法 网络协议
LVS、Nginx和HAProxy负载均衡器对比总结
LVS、Nginx和HAProxy负载均衡器对比总结
|
8月前
|
负载均衡 监控 网络协议
使用haproxy实现负载均衡集群
【4月更文挑战第14天】HAProxy提供高可用性、负载均衡以及基于TCP和HTTP应用的代理,快速并且可靠的一种解决方案。
291 1
|
8月前
|
负载均衡 网络协议 应用服务中间件
【亮剑】在Linux中构建高可用性和高性能网络服务的负载均衡工具HAProxy、Nginx和Keepalived。
【4月更文挑战第30天】本文介绍了在Linux中构建高可用性和高性能网络服务的负载均衡工具HAProxy、Nginx和Keepalived。HAProxy是一个高性能的开源TCP和HTTP负载均衡器,适合处理大量并发连接;Nginx是一个多功能Web服务器和反向代理,支持HTTP、HTTPS和TCP负载均衡,同时提供缓存和SSL功能;Keepalived用于监控和故障切换,通过VRRP实现IP热备份,保证服务连续性。文中详细阐述了如何配置这三个工具实现负载均衡,包括安装、配置文件修改和启动服务,为构建可靠的负载均衡系统提供了指导。
200 0