前言
Keepalived是一个用于实现高可用性的开源工具,主要用于实现基于VRRP协议的负载均衡和故障转移功能。它可以通过检测节点的健康状况,并自动切换到备份节点来确保服务的高可用性。
Keepalived支持多种检测方式,如ping、TCP连接等,并可以根据需要配置多个检测脚本。当某个节点状态异常时,Keepalived会自动执行预定义的操作,如启动或停止服务,以确保服务的连续性和可用性。
在实现高可用性方面,Keepalived广泛应用于Web服务器、负载均衡器、数据库服务器等领域,为企业提供了高效、稳定且可靠的服务。在DHCP服务方面,Keepalived可以通过监控DHCP服务的运行状态,自动切换到备份节点,避免因节点故障导致DHCP服务中断,从而确保网络设备和客户端能够正常获取IP地址和其他相关的配置信息。
一、Keepalived安装及配置
1.Keepalived安装
[root@localhost ~]#yum install keepalived.x86_64 -y
2.Keepalived配置
编辑Keepalived的配置文件/etc/keepalived/keepalived.conf
[root@localhost ~]#vim /etc/keepalived/keepalived.conf
[root@localhost ~]#cat /etc/keepalived/keepalived.conf
global_defs {router_id LVS_DEVEL#标识符 支持自定义
}vrrp_script chk_dhcp {
#检查脚本script "/etc/keepalived/check_dhcp.sh"#需要编写check_dhcp.sh脚本来检查DHCP服务是否正常interval 2
}vrrp_instance VI_1 {
#Virtual Router Redundancy Protocol(VRRP)实例名称state MASTERinterface ens33#网卡名称virtual_router_id 51#虚拟路由IDpriority 100#节点优先级virtual_ipaddress {192.168.241.11/24 dev ens33#虚拟IP地址和对应的网络接口名称}track_script {chk_dhcp}
}
3.编写检查脚本
创建/etc/keepalived/check_dhcp.sh脚本,用于检查DHCP服务状态是否正常,脚本内容如下:
[root@localhost ~]#vim /etc/keepalived/check_dhcp.sh
[root@localhost ~]#cat /etc/keepalived/check_dhcp.sh
#!/bin/bash
status=$(systemctl status dhcpd | grep -o 'Active: active')
if [ "$status" = "Active: active" ]
thenexit 0
elseexit 1
fi
以上脚本会检查DHCP服务的状态,如果DHCP服务处于运行状态,则返回0,否则返回1。
4.启动Keepalived
[root@localhost ~]#systemctl start keepalived.service
[root@localhost ~]#systemctl enable keepalived.service
#启动Keepalived服务并设为开机自启动
Created symlink from /etc/systemd/system/multi-user.target.wants/keepalived.service to /usr/lib/systemd/system/keepalived.service.
二、配置文件同步
若使用rsync工具同步DHCP配置文件,则需要在主从节点安装rsync,并编写同步脚本。以下是一个简单的同步脚本示例:
1.安装rsync
在主从节点上安装rsync
[root@node2 ~]#yum install rsync -y
[root@node3 ~]#yum install rsync -y
2.编写同步脚本
2.1主
在主节点上创建/etc/keepalived/sync-master.sh脚本,用于同步DHCP配置文件到备份节点:
[root@localhost ~]#vim /etc/keepalived/sync-master.sh
[root@localhost ~]#cat /etc/keepalived/sync-master.sh
#!/bin/bash
/usr/bin/rsync -avz --delete /etc/dhcp/ user@backup-node:/etc/dhcp/
#/etc/dhcp/配置文件路径 user为备份节点用户名 backup-node为备份节点IP地址或主机名
2.2备
在备份节点上创建/etc/keepalived/sync-backup.sh脚本,用于同步DHCP配置文件到主节点:
#!/bin/bash
/usr/bin/rsync -avz --delete /etc/dhcp/ user@master-node:/etc/dhcp/
#/etc/dhcp/为DHCP配置文件存储路径 user为主节点用户名 master-node为主节点IP地址或主机名
3.修改Keepalived配置文件
在Keepalived配置文件中添加以下内容,以指定同步脚本路径
vrrp_instance VI_1 {...notify_master /etc/keepalived/sync-master.shnotify_backup /etc/keepalived/sync-backup.sh
}
三、测试高可用部署
在两个节点上分别配置Keepalived,并检查DHCP服务的状态是否正常。当主节点宕机时,备份节点会自动接管服务,并通过rsync工具同步DHCP配置文件,确保DHCP服务的高可用性。