keepalived

是什么

keepalived是集群管理中保证集群高可用的一个服务软件,其功能类似于heartbeat,用来防止单点故障。

通常分布式系统采用主从模式,一个主机连接多个处理节点,主节点负责分发任务,而子节点负责处理业务,当主节点发生故障时,会导致整个系统发故障,我们把这种故障叫做单点故障。

工作原理

keepalived是以VRRP协议为实现基础的,VRRP全称Virtual Router Redundancy Protocol,即虚拟路由冗余协议。

虚拟路由冗余协议,可以认为是实现路由器高可用的协议,即将N台提供相同功能的路由器组成一个路由器组,这个组里面有一个master和多个backup,master上面有一个对外提供服务的vip(该路由器所在局域网内其他机器的默认路由为该vip),master会发组播,当backup收不到vrrp包时就认为master宕掉了,这时就需要根据VRRP的优先级来选举一个backup当master。这样的话就可以保证路由器的高可用了。

keepalived主要有三个模块,分别是core、check和vrrp。core模块为keepalived的核心,负责主进程的启动、维护以及全局配置文件的加载和解析。check负责健康检查,包括常见的各种检查方式。vrrp模块是来实现VRRP协议的。

实现高可用(HA)

  • 在服务器组内漂移的VIP, VIP是一个虚拟ip,不是一个固定配置在网卡上的ip,漂移的ip。当第一台服务器正常工作时,这个ip就属于这台服务器;当这个服务器出故障了,ip会漂移属于其他服务器。
  • Master独占VIP,其他Server检查Master可用性
  • keepalived并非专门针对Apache而设计
  • 常用于负载均衡技术环境
  • 组内服务器应提供相同内容和配置

安装:

1
sudo apt install keepalive

进入/etc/keepalived目录下,发现没有文件,要自己先建配置文件sudo vi keepalived.conf

简单配置:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21

global_defs {
notification_email { # 没有这一段也行, 建议这样配置
myemail@mycompany.com # 如果出现问题,就发送消息给这个邮件
}
notification_email_from keepalived@mycompany.com
smtp_server 192.168.1.150 # 邮件服务器 ip
smtp_connect_timeout 30
router_id mycompany_web_prod
}
vrrp_instance VI_1 {
smtp_alert # 如果出问题,就使用邮件通知
interface ens33 # 网卡优先级
virtual_router_id 51 # 指定虚拟服务器id,这个id任意取的,定义服务器组,同组的服务器一样的
priority 100 # 组成员优先级,同组的不一样
advert_int 5 # 通告间隔5秒
virtual_ipaddress {
192.168.50.101 # VIP(DHCP以外)
}
}

然后安装第二台服务器做测试, 和master服务器配置一样

模拟切换:

  • 暂停master keepalived sudo systemctl stop keepalived
  • 然后第二胎服务器会接管 , 期间虚拟ip会从master服务器漂移在第二台服务器