1 keepalived
lvs+keepalive:高可用集群
keepalived为lvs应运而生的高可用服务,lvs的调度器无法做高可用,也是keepalived这个软件,实现的是调度器的高可用
但是:keepalived不是专门为lvs集群服务的,可以做其他代理服务器的高可用。
lvs的高可用集群:主调度器和备调度器(可以有多个)一主二备 一主一备。
主调度器能够正常运行时,由主调度器进行后端真实服务器的分配处理。其余的备用调度器处在冗余状态,不参与集群的运转,只有主调度器出现了故障无法运行,备调度器才会承担主调度器的工作。
一旦主调度器恢复工作,继续由主调度器进行处理,备调度器又成了冗余。
2.VRRP
VRRP:keepalived是基于vrrp协议实现lvs服务的高可用。解决了调度器单节点的故障问题。
VRRP协议:提供网络路由器的可靠性开发的一种协议。
选举出主和备,预先设备好了主和备的优先级,主的优先级较高,备的优先级低,一旦开启服务器,优先级高的,会自动抢占主的位置。
VRRP组播通信:224.0.0.18 VRRP协议当中的主备服务器通过组播地址进行通信,交换主备服务器之间的运行状态,主服务器会发生VRRP报文消息,以告知其他备服务器,主服务器现在的状态。
主备切换:主服务器发生故障或者不可达,VRRP协议会把请求转移到备服务器,通过组播地址,VRRP可以迅速的通知其他服务器发生了主备切换,确保新的主服务器可以正常的处理客户端的请求
故障恢复:一旦主服务器恢复通信,由组播地址进行通信,发现恢复的主服务器优先级更高,会抢占原主服务器的位置,成为主服务器,调度和接收请求。
3.keepalived的体系架构
全局模块:core模块 负载整个keepalived启动加载和维护
VRRP模块:实现vrrp协议,主备切换
check模块:负责健康检查,检查后端真实服务器的健康检查。配置在真实服务器的模块当中
4.lvs-DR模式结合keepalived
test1:主调度器 192.168.233.10
test2:备调度器 192.168.233.20
后端服务器1 192.168.233.30
后端服务器2 192.168.233.40
vip 192.168.66.100
客户端:192.168.233.61
systemctl stop firewalld
setenforce 0
test1 test2
yum -y install ipvsadm keepalived
cd /etc/keepalived
ls
cp keepalived.conf keepalived.conf.bak
test1
vim keepalived.conf
set nu
10行修改
smtp_server 127.0.0.1
data:image/s3,"s3://crabby-images/b87a4/b87a435a115cca650da17651db4d0a200d65d992" alt=""
12行修改
router_id LVS_01
data:image/s3,"s3://crabby-images/0850c/0850ca030f2d9ce9ac21fd9f14b95262153536d1" alt=""
第15行注释
#vrrp_strict
data:image/s3,"s3://crabby-images/fce5e/fce5e81c624ff5449bcce41b58fde7fc20f60216" alt=""
22行
data:image/s3,"s3://crabby-images/415d4/415d475f4044a118e03dbf27971257897a237e34" alt=""
26行
data:image/s3,"s3://crabby-images/8dead/8dead81e04b2656e2e031ea37f42c0ba0e65a96e" alt=""
28行 优先级
data:image/s3,"s3://crabby-images/91f98/91f988655115d0193296112f45526f21294652f1" alt=""
29行
data:image/s3,"s3://crabby-images/5649e/5649edeba8dd9bd7edea89ca211598889e087391" alt=""
31行 验证密码,要主备一致 默认即可
data:image/s3,"s3://crabby-images/aa0f9/aa0f91b88d1253702fe1e9100cbb5512ecb4b9c5" alt=""
35行vip地址
data:image/s3,"s3://crabby-images/8d68f/8d68f0ab50d7bbdf346440c9dff325a641cf217a" alt=""
41行
data:image/s3,"s3://crabby-images/f4b2d/f4b2dd9993bfe17a469cc9a8770456d25a857842" alt=""
52行
先把54行 100dd
data:image/s3,"s3://crabby-images/29f01/29f01e4384cf0f0d5ff6e08283dccab3112de324" alt=""
配置一个 复制粘贴
data:image/s3,"s3://crabby-images/ae783/ae783c9a93a00b8925193c6d30b33116ee5530a2" alt=""
systemctl restart keepalived.service
所有注释都要删除
ifconfig
data:image/s3,"s3://crabby-images/00f05/00f055db445e3e2df4eada840e5e555032b1b5dc" alt=""
打开/etc/sysctl.conf
data:image/s3,"s3://crabby-images/45e6a/45e6a5d7b105ba144be9e2f3948d7403c2ae4aad" alt=""
sysctl -p
test2:
scp root@192.168.66.15:/etc/keepalived/keepalived.conf /etc/keepalived/keepalived.conf
vim /etc/keepalived
systemctl restart keepalived
ipvsadm -ln
test3,4
yum -y install nginx
test4
cd /usr/local/nginx/html
vim index.html
this is test4
vim /etc/sysconfig/network-scripts/ifcfg-lo:0
DEVICE=lo:0
ONBOOT=yes
IPADDR=192.168.66.100
NETMASK=255.255.255.255
ifup ifcfg-lo:0
route add -kost 192.168.233.100 dev lo:0
vim /etc/sysctl.conf
net.ipv4.conf.lo.arp_ignore = 1
net.ipv4.conf.lo.arp_announce = 2
net.ipv4.conf.all.arp_ignore = 1
net.ipv4.conf.all.arp_announce = 2
sysctl -p
test3 同理
客户机:
curl 192.168.233.100
data:image/s3,"s3://crabby-images/6104a/6104a3ac65fcdaf30a228826758a522623a7c384" alt=""
test1
ipaddr
data:image/s3,"s3://crabby-images/a0f8f/a0f8f9f9d905bc17c42c11564935be31a647ef9c" alt=""
test2
ip addr
data:image/s3,"s3://crabby-images/daf3d/daf3d212cb5fa3d0bb2ba2b15c1c9c8e913d2b87" alt=""
5.脑裂
脑裂:主和备同时拥有vip地址,在高可用系统当中,联系两个节点的心跳线,本来是一体的,动作协调的高可用系统。心跳线断开之后,分裂成两个独立的个体。主备之间失去了联系,都以为是对方出现了故障,两个调度器,就像脑裂人一样,开始抢占主的位置,抢占vip,主也有vip,备也有vip地址,导致整个集群失败。
软件层面:
1.配置文件
2.通过tcpdump抓包分析
重启
网络层面:
高可用服务器之间心跳线检测失败。主备之间无法进行通信,
硬件层面:
连接主备之间的心跳线老化
网卡或者网卡驱动失效,IP地址配置冲突
防火墙没有配置心跳线消息的传输通道,导致检测失败
后端服务器的配置问题,心跳方式不同,心跳广播冲突,软件bug
如何解决keepalived脑裂问题:
1、硬件:准备两条心跳线,这样断了一条,依然能够传输心跳消息
2、设置防火墙,一定要让心跳消息通过
3、依靠监控软件,实时监测(zabbix)第一时间邮件告警
6.nginx+keepalived
nginx 3 台
nginx1 192.168.233.61 主
nginx2 192.168.233.62 备
nginx3 192.168.233.63 客
nginx先关防火墙
nginx1 nginx2
systemctl stop firewalld
setenforce 0
systemctl restart nginx
yum -y install keepalived
nginx1
cd /etc/keepalived
cp keepalived.conf keepalived.conf.bak
vim keepalived.conf
data:image/s3,"s3://crabby-images/6e768/6e7686a4092eb0ee7e2de8e07c11add7631dc1f1" alt=""
data:image/s3,"s3://crabby-images/81eb0/81eb062e427d804eabd1daac2bfd2849f4063865" alt=""
data:image/s3,"s3://crabby-images/487be/487be085245df865a42384c14e6887e00dd31ad5" alt=""
剩余全部删除
在全局和vrrp之间插一段
data:image/s3,"s3://crabby-images/37dd7/37dd702643b3da4a6711959d187ab080fe26d840" alt=""
vrrp_script check_nginx {
script "/opt/check_nginx.sh"
interval 5
}
data:image/s3,"s3://crabby-images/7c552/7c552ce7ed6a9ebadaf07311b058365361b96dad" alt=""
nginx2
data:image/s3,"s3://crabby-images/1e885/1e885f52cba8d6cbadc470ca4af46c2e53e09d81" alt=""
vim
data:image/s3,"s3://crabby-images/c574c/c574c8dfbaff7a395f5e977241ccecced6e2ba2b" alt=""
data:image/s3,"s3://crabby-images/712de/712de779c3b2521536c125376650dfca236c58a2" alt=""
cd /opt/
vim check_nginx.sh
#!/bin/bash
/usr/bin/curl -I http://localhost &> /dev/null
if [ $? -ne 0 ]
then
systemctl stop keepalived
fi
wq!
chmod 777 check_nginx.sh
sz check_nginx.sh
nginx1
cd /opt
把sh 投进去
chmod 777 check_nginx.sh
nginx1
systemctl restart keepalived
ip addr
data:image/s3,"s3://crabby-images/d89e2/d89e210a94e2130effdbc2fb5e98caa69d126cf8" alt=""
nginx2
systemctl restart keepalived
ipaddr
data:image/s3,"s3://crabby-images/d4172/d41727a19a59643c1f870c46b59f24efd1d183eb" alt=""
nginx1
systemctl stop nginx
nginx2
ip addr
data:image/s3,"s3://crabby-images/fb153/fb1535f51d4d04e39781f9df67b05ad8445f9668" alt=""
nginx1
systemctl restart nginx
systemctl restart keepalived
ip addr
data:image/s3,"s3://crabby-images/a21e8/a21e87a1dfd14de781fd5975073be0c1d9ccb7e7" alt=""
test2
data:image/s3,"s3://crabby-images/79846/79846cc73a9a9b2a6338330c128543155ee317d0" alt=""