20260422 Keepalvied 高可用技术实践

Keepalvied 高可用技术实践

主机名 IP地址 服务器
client.jiang.cloud 10.1.8.21 客户端
web1.jiang.cloud 10.1.8.11 web1服务器
web2.jiang.cloud 10.1.8.12 web2服务器

一、配置 web

bash 复制代码
[root@web1 web2 ~ 18:37:53]# yum install -y nginx
# 部署 web
[root@web1 web2 ~ 18:38:50]# echo Welcome to $(hostname) > /usr/share/nginx/html/index.html
[root@web1 web2~ 18:39:48]# systemctl enable nginx.service --now

# 访问后端 nginx
[root@client1 ~ 18:37:24]# curl 10.1.8.11
Welcome to web1.jiang.cloud
[root@client1 ~ 18:41:09]# curl 10.1.8.12
Welcome to web2.jiang.cloud

二、配置 keepalived

2.1 配置 web2

web2 作为备节点。

bash 复制代码
[root@web2 ~ 18:40:57]# yum install -y keepalived
[root@web2 ~ 18:42:02]# cp /etc/keepalived/keepalived.conf{,.ori}
[root@web2 ~ 18:42:19]# vim /etc/keepalived/keepalived.conf
! Configuration File for keepalived

global_defs {
	router_id web2
}

vrrp_instance nginx {
    state BACKUP
    interface ens33
    virtual_router_id 51
    priority 100
    advert_int 1
    authentication {
    	auth_type PASS
    	auth_pass jiang@123
	}
virtual_ipaddress {
		10.1.8.100/24
	}
}

说明:

router_id web2,定义路由器名称,每个节点使用不同的名称。

state BACKUP,定义节点角色为备节点,MASTER则代表主节点。

interface ens33,定义VIP配置到该接口。

virtual_router_id 51 ,定义虚拟路由器ID,范围1-255,每个节点使用相同名称。

priority 100,定义节点优先级,值越大优先级越高。

authentication ,定义心跳认证。

virtual_ipaddress ,定义虚拟VIP。

bash 复制代码
# 启动 keepalived 服务
[root@web2 ~ 18:45:55]# systemctl enable keepalived.service --now

# 查看 IP
[root@web2 ~ 18:46:10]# ip -br a show ens33
ens33            UP             10.1.8.12/24 10.1.8.100/24 fe80::20c:29ff:fec6:de41/64 

2.2 配置 web1

web1 作为主节点。

bash 复制代码
[root@web1 ~ 18:40:45]# yum -y install keepalived
[root@web1 ~ 18:47:11]# cp /etc/keepalived/keepalived.conf{,.ori}
[root@web1 ~ 18:47:47]# vim /etc/keepalived/keepalived.conf
! Configuration File for keepalived

global_defs {
	router_id web1
}

vrrp_instance nginx {
    state MASTER
    interface ens33
    virtual_router_id 51
    # master节点优先级要高于BACKUP节点
    priority 110
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass jiang@123     # 密码长度 不能超过 8 位(超过则 只取前8位
    }
	virtual_ipaddress {
		10.1.8.100/24
	}
}
bash 复制代码
# 启动服务
[root@web1 ~ 18:51:11]# systemctl stop keepalived.service

# 查看 IP,VIP 切换到 web1
[root@web1 ~ 18:50:58]# ip -br a show ens33
ens33            UP             10.1.8.11/24 10.1.8.100/24 fe80::20c:29ff:feea:2198/64
[root@web2 ~ 18:46:23]# ip -br a show ens33
ens33            UP             10.1.8.12/24 fe80::20c:29ff:fec6:de41/64 

三、高可用验证

bash 复制代码
# 访问 web
[root@client ~ 18:54:58]# curl 10.1.8.100
Welcome to web1.jiang.cloud

# 关闭 web1 的 keepalive服务,再次访问
[root@web1 ~ 18:54:49]# systemctl stop keepalived.service 
[root@client ~ 18:54:09]# curl 10.1.8.100
Welcome to web2.jiang.cloud

# 再次启动 web1 的keepalive服务,再次访问
[root@web1 ~ 18:54:49]# systemctl start keepalived.service 
[root@client ~ 18:54:58]# curl 10.1.8.100
Welcome to web1.jiang.cloud
相关推荐
逸巽散人2 小时前
【无标题】
网络
kaoa0002 小时前
Linux入门攻坚——77、虚拟化技术基础原理-2
linux·服务器·网络
沪漂阿龙3 小时前
面试题详解:大模型设计沙箱全攻略——LLM Sandbox、Agent 工具执行、代码沙箱、安全隔离、权限控制与工程落地
网络·数据库·人工智能·安全
qq_543447823 小时前
Tcping测速是什么?Tcping测速核心概念解析
服务器·网络·php
婷婷_1723 小时前
【PCIe 验证每日学习・Day36】PCIe 存储器寻址空间与 BAR 底层原理
网络·学习·程序人生·芯片·pcie
海南java第二人3 小时前
ClickHouse 自然语言统一查询:让数据对话成为现实
网络·数据库·clickhouse
.千余4 小时前
【Linux 】网络基础1
linux·运维·服务器·开发语言·网络·学习
小短腿的代码世界4 小时前
Qt低级网络编程与零拷贝技术在高频交易中的应用:从QTcpSocket到共享内存的全链路优化
开发语言·网络·qt
ACP广源盛139246256734 小时前
IX8024 对标 ASM2824 @ACP#搭配昆仑芯 P800 构建 AI 服务器 PCIe4.0 高速互联架构
网络·人工智能·嵌入式硬件·电脑
老詹图解IT4 小时前
深度剖析:近期 Linux 内核重大漏洞与 AI 时代的安全挑战—兼答“制造恐慌“之说,以及Linus邮件背后的真实故事
网络·安全