Keepalived实现HAProxy高可用搭建

Keepalived实现HAProxy高可用

文章目录

拓扑表格如下

主机名 IP 环境
master 192.168.242.67 Keepalived + HAProxy
master-backup 192.168.242.68 Keepalived + HAProxy
server1 192.168.242.69 nginx
server2 192.168.242.70 nginx

拓扑结构(示例)

nginx安装(所有server)

bash 复制代码
# 添加nginx yum源
vi /etc/yum.repos.d/nginx.repo

[nginx-stable]
name=nginx stable repo
baseurl=http://nginx.org/packages/centos/$releasever/$basearch/
gpgcheck=1
enabled=1
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true
[nginx-mainline]
name=nginx mainline repo
baseurl=http://nginx.org/packages/mainline/centos/$releasever/$basearch/
gpgcheck=1
enabled=0
gpgkey=https://nginx.org/keys/nginx_signing.key
module_hotfixes=true

# 安装nginx
yum -y install nginx

# 修改网页内容(便于区分)
vi /usr/share/nginx/html/index.html
# 启动
systemctl start nginx

HAProxy安装(主备机相同)

bash 复制代码
# 安装HAProxy
yum install haproxy -y
# 安装psmisc,便于后面使用killall命令
yum install psmisc -y

HAProxy配置(主备机相同)

vi /etc/haproxy/haproxy.cfg

注释如下内容:

bash 复制代码
# 末尾添加如下:

 frontend web_lb  # 前端负载均衡
    bind *:80
    stats uri /ha_stats
    default_backend web_back

backend web_back  # 后台负载均衡
    balance roundrobin
    server web01 192.168.242.69:80 check weight 1
    server web02 192.168.242.70:80 check weight 1
bash 复制代码
# 启动haproxy
systemctl restart haproxy

Keepalived安装与配置

Keepalived安装(主备机相同)

bash 复制代码
# 安装依赖
yum install -y curl gcc openssl-devel libnl3-devel net-snmp-devel
# 安装keepalived
yum install -y keepalived

Keepalived配置

vi /etc/keepalived/keepalived.conf

yaml 复制代码
 # -------------------------------------------------主机------------------------------------
 
 ! Configuration File for keepalived

global_defs {
	router_id LVS_DEVEL  # 虚拟路由名称
}

# 健康检查脚本内容
vrrp_script chk_haproxy {
    script "killall -0 haproxy"  # 使用killall-0检查haproxy实例是否存在,性能高于ps命令
    interval 2  # 脚本运行周期
    weight 2  # 每次检查的加权权重值
}
# 虚拟路由配置
vrrp_instance VI_1 {
    state MASTER  # 本机实例状态,MASTER/BACKUP,备机配置文件中请写BACKUP
    interface ens33  # 本机网卡名称,使用ifcoffig命令查看
    virtual_router_id 67  # 虚拟路由编号,主备机保持一致
	priority 100  # 本机初始权重,备机请填写小于主机的值
	advert_int 1  # 争抢虚地址的周期,秒
    virtual_ipaddress {
        192.168.242.100  # 虚地址IP,主备机保持一致
	}
    track_script {
		chk_haproxy  # 对应的健康检查配置
    }
}

 # -------------------------------------------------备机------------------------------------
  ! Configuration File for keepalived

global_defs {
	router_id LVS_DEVEL  # 虚拟路由名称
}

# 健康检查脚本内容
vrrp_script chk_haproxy {
    script "killall -0 haproxy"  # 使用killall-0检查haproxy实例是否存在,性能高于ps命令
    interval 2  # 脚本运行周期
    weight 2  # 每次检查的加权权重值
}
# 虚拟路由配置
vrrp_instance VI_1 {
    state BACKUP  # 本机实例状态,MASTER/BACKUP,备机配置文件中请写BACKUP
    interface ens33  # 本机网卡名称,使用ifcoffig命令查看
    virtual_router_id 67  # 虚拟路由编号,主备机保持一致
	priority 99  # 本机初始权重,备机请填写小于主机的值
	advert_int 1  # 争抢虚地址的周期,秒
    virtual_ipaddress {
        192.168.242.100  # 虚地址IP,主备机保持一致
	}
    track_script {
		chk_haproxy  # 对应的健康检查配置
    }
}

启动Keepalived systemctl start keepalived

验证

负载均衡验证

检查主备ip

可以发现主机现在承担vip服务

关闭主机HAProxy服务

可见ip成功漂移(并且浏览器192.168.242.100的虚拟ip依然能够访问)

相关推荐
小白的白是白痴的白2 分钟前
配置yarn模式
linux·运维·服务器
s_little_monster3 分钟前
【Linux】socket网络编程之TCP
linux·运维·网络·笔记·学习·tcp/ip·学习方法
林鸿风采6 分钟前
内网服务器之间传输单个大文件最佳解决方案
linux·python·文件传输
belldeep16 分钟前
WSL 安装 Debian 12 后,Linux 如何安装 redis ?
linux·redis·debian
煤灰24218 分钟前
Linux上的网络编程-初探
linux·网络
马志远的生信笔记36 分钟前
质控脚本来喽
linux·数据分析
在下千玦1 小时前
#在 CentOS 7 中手动编译安装软件操作及原理
linux
Penguido2 小时前
基于 Nexus 在 Dockerfile 配置 yum, conda, pip 仓库的方法和参考
linux·docker·centos·conda·pip
Fireworkitte2 小时前
企业级常用的 CentOS版本
linux·运维·centos
liulilittle3 小时前
MAC-OS X 命令行设置IP、掩码、网关、DNS服务器地址
linux·网络·macos