目录
[1、在192.168.115.3 和192.168.115.4 上安装ipvs和keepalived:](#1、在192.168.115.3 和192.168.115.4 上安装ipvs和keepalived:)
一、作用
Keepalived 和 LVS(Linux Virtual Server)结合使用可以实现高可用性的负载均衡。在 LVS 中,DR(Direct Routing)模式是其中一种常见的负载均衡模式。
在 Keepalived + LVS(DR)的架构中,Keepalived负责监控主服务器的状态以及进行故障检测。当主服务器发生故障时,Keepalived会自动将虚拟 IP 地址(VIP)移动到备份服务器上,以确保服务的连续性。
而 LVS(DR)负责实际的负载均衡功能。在 DR 模式下,LVS 将负载均衡器配置为直接路由数据包。当客户端发送请求时,数据包会直接发送到目标服务器,而负载均衡器只处理响应数据包的返回路由。这种方式避免了数据包的二次转发,减少了负载均衡器的开销,提高了性能。
这种架构的优点是:
-
可以实现高可用性,通过 Keepalived 监控主服务器的状态并自动进行故障切换。
-
可以实现负载均衡,通过 LVS 将客户端请求均匀地分发到多个服务器上,提高服务性能和可扩展性。
-
DR 模式减少了数据包的二次转发,降低了负载均衡器的负载,提高了性能。
总之,Keepalived + LVS(DR)的组合可以提供高可用性的负载均衡解决方案,确保服务的连续性和性能的提升。
二、安装
在四台虚拟机上,我们以如下方式搭建集群:
192.168.115.3 lvs+keepalived
192.168.115.4 lvs+keepalived
192.168.115.5 nginx
192.168.115.6 nginx
1、在192.168.115.3 和192.168.115.4 上安装ipvs和keepalived:
yum install -y keepalived
data:image/s3,"s3://crabby-images/2367c/2367ca9037c36cb1ac1ed4a35241d342c72df0e5" alt=""
yum install -y ipvsadm
data:image/s3,"s3://crabby-images/84eed/84eedb83de84d3e5844e7197dffa8b8faf643b96" alt=""
modprobe ip_vs
lsmod |grep ip_vs
data:image/s3,"s3://crabby-images/f837d/f837de7d5a58c1aeded0d5baecc91aaa3643b59d" alt=""
2、配置keepalived
主(192.168.115.3)
vim /etc/keepalived/keepalived.conf
修改后
global_defs {
router_id LVS_DEVEL1
}
vrrp_instance VI_1 {
state MASTER
interface ens33
virtual_router_id 51
priority 100
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
192.168.115.200
}
}
virtual_server 192.168.115.200 80 {
delay_loop 6
lb_algo rr
lb_kind DR
#persistence_timeout 50
protocol TCP
real_server 192.168.115.5 80 {
weight 1
HTTP_GET {
url {
path /
}
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}
real_server 192.168.115.6 80 {
weight 1
HTTP_GET {
url {
path /
}
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}
}
备(192.168.115.4)
vim /etc/keepalived/keepalived.conf
修改后
global_defs {
router_id LVS_DEVEL2
}
vrrp_instance VI_1 {
state BACKUP
interface ens33
virtual_router_id 51
priority 90
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
192.168.115.200
}
}
virtual_server 192.168.115.200 80 {
delay_loop 6
lb_algo rr
lb_kind DR
# persistence_timeout 50
protocol TCP
real_server 192.168.115.5 80 {
weight 1
HTTP_GET {
url {
path /
}
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}
real_server 192.168.115.6 80 {
weight 1
HTTP_GET {
url {
path /
}
connect_timeout 3
nb_get_retry 3
delay_before_retry 3
}
}
}
3、查看lvs节点状态
systemctl start keepalived
ipvsadm -ln
主
data:image/s3,"s3://crabby-images/39ebb/39ebb1c00a5847ad32e86dc2dd7a27119698ea4c" alt=""
ip a
data:image/s3,"s3://crabby-images/64c28/64c28882a827ac8af91a83009a648e7c88e5c0be" alt=""
备
data:image/s3,"s3://crabby-images/4e3d0/4e3d09fc5e252882090a3b325699330568efe89b" alt=""
4、web节点配置
在192.168.115.5 和192.168.115.6 上安装nginx
data:image/s3,"s3://crabby-images/a8eaa/a8eaa96ab82932f27128e2d9d0eb27bcab357f2c" alt=""
data:image/s3,"s3://crabby-images/bd25f/bd25f7e1a149b25dd84abd8383145bd812d0c115" alt=""
5、在web节点上调整ARP参数
vim /etc/sysctl.conf
net.ipv4.conf.all.arp_ignore=1
net.ipv4.conf.all.arp_announce=2
net.ipv4.conf.default.arp_ignore=1
net.ipv4.conf.default.arp_announce = 2
net.ipv4.conf.lo.arp_ignore = 1
net.ipv4.conf.lo.arp_announce=2
data:image/s3,"s3://crabby-images/e97f3/e97f3c56a15691b3249d5ffc49ac3d4a085f72d8" alt=""
sysctl -p
data:image/s3,"s3://crabby-images/4c6e7/4c6e7ed0b2b8a39fe5431128192271d83ac7aa02" alt=""
6、配置虚拟IP地址与添加回环路由
cd /etc/sysconfig/network-scripts/
cp ifcfg-lo ifcfg-lo:0
vim ifcfg-lo:0
data:image/s3,"s3://crabby-images/0d36d/0d36df905e458b8dce71681afc105b5589324cea" alt=""
ip a
data:image/s3,"s3://crabby-images/293be/293be75791507f1706ea49f6e809e416eb6f69b6" alt=""
添加回环路由 route add -host 192.168.115.200/32 dev lo:0
7、配置nginx网页文档
data:image/s3,"s3://crabby-images/7dbda/7dbda0585048cded411a2536ed364e7a9777dc12" alt=""
data:image/s3,"s3://crabby-images/43684/4368437837015a94f7a56ed5b0e41200a9f0821c" alt=""
8、启动服务
data:image/s3,"s3://crabby-images/4b90c/4b90c5b7bc65ccf42a77795733640073c3e7490b" alt=""
data:image/s3,"s3://crabby-images/f1dd0/f1dd0184f012c49520b262dd0d0c9ec6258f4dfe" alt=""
9、测试
客户端访问
data:image/s3,"s3://crabby-images/21b73/21b73db8fea8e31b82cc4c79cd5fa77af0fdba2b" alt=""
data:image/s3,"s3://crabby-images/d0f65/d0f650fdc436a3b1539b9c2d4be0db68f5fe8a3f" alt=""
断掉主,测试备
主
data:image/s3,"s3://crabby-images/12147/12147824a688a073bd960483655b3fa37281533d" alt=""
备
data:image/s3,"s3://crabby-images/ba060/ba0602b7134a01b6fefd28c8a957340818412b78" alt=""
客户端访问
data:image/s3,"s3://crabby-images/c2f23/c2f231cc8027ad4bbf6a7e3e33d60371187bea85" alt=""
data:image/s3,"s3://crabby-images/27440/27440b7f6dabd616492b6e55ea71041c05666235" alt=""