LVS+Keepalived群集

Keepalived

■什么是Keepalived

•Keepalived起初是为LVS设计的,专门用来监控集群系统中各个服务节点的状态,它根据TCP/IP参考模型的第三、第四层、第五层交换机制检测每个服务节点的状态,如果某个服务器节点出现异常,或者工作出现故障,Keepalived将检测到,并将出现的故障的服务器节点从集群系统中剔除,这些工作全部是自动完成的,不需要人工干涉,需要人工完成的只是修复出现故障的服务节点。
•后来Keepalived又加入了VRRP的功能,VRRP(Vritrual Router Redundancy Protocol,虚拟路由冗余协议)出现的目的是解决静态路由出现的单点故障问题,通过VRRP可以实现网络不间断稳定运行,因此Keepalvied 一方面具有服务器状态检测和故障隔离功能,另外一方面也有HA cluster功能,下面介绍一下VRRP协议实现的过程。

Keepalived工具介绍

专为LVS和HA设计的一款健康检查工具

  • 支持故障自动切换(Failover)
  • 支持节点健康状态检查(Health Checking)
    • 判断LVS负载调度器、节点服务器的可用性,当master主机出现故障及时切换到backup 节点保证业务正常,当master故障主机恢复后将其重新加入群集并且业务重新切换回master节点。

Keepalived实现原理剖析

VRRP(虚拟路由冗余协议)是针对路由器的一种备份解决方案

  • ·由多台路由器组成一个热备组,通过共用的虚拟IP地址对外提供服务
  • 每个热备组内同时只有一台主路由器提供服务,其他路由器处于冗余状态
  • 若当前在线的路由器失效,则其他路由器会根据设置的优先级自动接替虚拟IP地址,继续提供服务

Keepalived的原理

  • Keepalived是一个基于VRRP协议来实现的LVS服务高可用方案,可以解决静态路由出现的单点故障问题。
    • 在一个LVS服务集群中通常有主服务器(NASTR)和备份服务器(BACKOIP)两种角色的服务器,但是对外表现为一个虚拟IP,主服务器会发送VR&E通告信息给备份服务器,当备份服务器收不到VR消息的时候,即主服务器异常的时候,备份服务器就会接管虚拟T,继续提供服务,从而保证了高可用性。

LVS+Keepalived 高可用群集部署

环境配置

  • 宿主机:Win10 专业工作站版本
  • VMware:16 Pro(16.1.0)
  • CentOS 7
  • 网络适配器:均为 NAT 模式
  • 网卡配置:均为静态获取 IP
  • YUM 源:本地
  • Win客户端:192.168.239.115
  • DR 服务器(负载调度器)(CentOS 7-1):192.168.239.110
  • DR服务器:192.168.239.117
  • Web 服务器 1(CentOS 7-2):192.168.239.111
  • Web 服务器 2(CentOS 7-3):192.168.239.112
  • NFS 服务器(CentOS 7-4):192.168.239.113
  • VIP:192.168.239.116

1、配置负载调度器(192.168.239.110、192.168.239.117相同)

详情看LVS-DR的部署

2、部署NFS共享服务器(192.168.239.113)

详情看LVS-DR的部署

3、配置节点服务器:两台相同(192.168.239.111、192.168.239.112)

详情看LVS-DR的部署

4、配置keeplived(主、备DR服务器上都要设置)

yum -y install keepalived
#安装软件包

route add -host 192.168.126.166 dev ens33:0
#这一步很重要!禁锢虚拟网卡

cd /etc/keepalived/
cp keepalived.conf keepalived.conf.bak
#备份


vim keepalived.conf

global_defs {						#定义全局参数
    #第10行,邮件服务指向本地
	smtp_server 127.0.0.1
    #第12行,指定服务器(路由器)的名称,主备服务器名称须不同,主为LVS_01,备为LVS_02
	router_id LVS_01
}

vrrp_instance VI_1 {				#定义VRRP热备实例参数
#20行,指定热备状态,主为MASTER,备为BACKUP
    state MASTER
    #21行,指定承载vip地址的物理接口
    interface ens33
    #第22行,指定虚拟路由器的ID号,每个热备组保持一致	
    virtual_router_id 10
    #第23行,指定优先级,数值越大优先级越高,主为100,备为99
    priority 100
    advert_int 1					#通告间隔秒数(心跳频率)
    authentication {				#定义认证信息,每个热备组保持一致
		auth_type PASS				#认证类型
        第27行,指定验证密码,主备服务器保持一致
        auth_pass 123123
    }
    virtual_ipaddress {				#指定群集vip地址
        192.168.126.166
    }
}
#第34行,指定虚拟服务器地址(VIP)、端口,定义虚拟服务器和Web服务器池参数
virtual_server 192.168.126.166 80 {
    delay_loop 6					#健康检查的间隔时间(秒)
    lb_algo rr						#指定调度算法,轮询(rr)
    #第37行,指定群集工作模式,直接路由(DR)
    lb_kind DR
    persistence_timeout 50			#连接保持时间(秒)
    protocol TCP					#应用服务采用的是 TCP协议
    #第41行,指定第一个Web节点的地址、端口
    real_server 192.168.126.13 80 {
        weight 1					#节点的权重
        第43行,添加以下健康检查方式		
        TCP_CHECK {
			connect_port 80			#添加检查的目标端口
			connect_timeout 3		#添加连接超时(秒)
			nb_get_retry 3			#添加重试次数
			delay_before_retry 3	#添加重试间隔
		}
	}

	real_server 192.168.126.14 80 {		#添加第二个Web节点的地址、端口
        weight 1
        TCP_CHECK {
			connect_port 80
			connect_timeout 3
			nb_get_retry 3
			delay_before_retry 3
		}
	}

#删除后面多余的配置
}


systemctl start keepalived
#开启服务

ip addr show dev ens33
#查看虚拟网卡vip

4.测试

在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值