前言


基于Keepalived实现LVS双主高可用集群。什么是Keepalived呢,keepalived观其名可知,保持存活,在网络里面就是保持在线了, 也就是所谓的高可用或热备,用来防止单点故障的发生。本文将详细讲述Keepalived工作原理及高可用解决方案的实现。

相关介绍

Keepalived简介

Keepalived采用VRRP(virtual router redundancy protocol,虚拟路由冗余协议)热备份协议,以软件的方式实现linux服务器的多机热备功能。VRRP是针对路由器的一种备份解决方案——由多台路由器组成一个热备组。通过共用的虚拟IP地址对外提供服务;每个热备组内同一时刻只有一台主服务器提供服务,其他服务器处于冗余状态,若当前在线的服务器失败,其他服务器会自动接替(优先级决定接替顺序)虚拟IP地址,以继续提供服务。


工作原理

Keepalived组件介绍

core:keepalived的核心,复杂主进程的启动和维护,全局配置文件的加载解析等

check:负责healthchecker(健康检查),包括了各种健康检查方式,以及对应的配置的解析包括LVS的配置解析

vrrp:VRRP子进程,VRRP子进程就是来实现VRRP协议的

libip*:LVS相关


基于Keepalived实现LVS双主高可用集群_java


由图可知,两个子进程都被系统WatchDog看管,两个子进程各自负责自己的事,healthchecker子进程负责检查各自服务器的健康程度,例如HTTP,LVS等等,如果healthchecker子进程检查到MASTER上服务不可用了,就会通知本机上的VRRP子进程,让他删除通告,并且去掉虚拟IP,转换为BACKUP状态。

高可用解决方案

实验拓扑

基于Keepalived实现LVS双主高可用集群_java_02


配置过程

HA集群配置前提

时间同步、基于主机名互相通信、SSH互信

请确保两个节点时间同步,可用ntpdate向时间服务器同步



基于主机名互相通信


SSH互信


安装所需程序


配置keepalived


将配置文件同步给另一个节点


修改另一个节点配置文件

基于Keepalived实现LVS双主高可用集群_java_03


Real Server配置

配置内核参数及VIP

基于Keepalived实现LVS双主高可用集群_java_04


准备测试页面

基于Keepalived实现LVS双主高可用集群_java_05基于Keepalived实现LVS双主高可用集群_java_06


测试页面

基于Keepalived实现LVS双主高可用集群_java_07


keepalived节点准备应急页面

基于Keepalived实现LVS双主高可用集群_java_08基于Keepalived实现LVS双主高可用集群_java_09


测试


启动keepalived

基于Keepalived实现LVS双主高可用集群_java_10


查看两节点的ip和ipvs规则情况

基于Keepalived实现LVS双主高可用集群_java_11基于Keepalived实现LVS双主高可用集群_java_12基于Keepalived实现LVS双主高可用集群_java_13


访问测试

基于Keepalived实现LVS双主高可用集群_java_14基于Keepalived实现LVS双主高可用集群_java_15基于Keepalived实现LVS双主高可用集群_java_16基于Keepalived实现LVS双主高可用集群_java_17


模拟其中一个主节点故障

基于Keepalived实现LVS双主高可用集群_java_18


再次查看两节点的ip和ipvs规则情况

基于Keepalived实现LVS双主高可用集群_java_19基于Keepalived实现LVS双主高可用集群_java_20


由此可见,一个主节点挂掉以后所有的VIP和ipvs规则都会转移到另一个节点,所以访问也不会受到任何影响,这里就不再测试。如果故障节点重新上线,资源还会再次回到工作节点。


下面我们模拟两个RS节点全部故障,看一下sorry_server是否可以工作


基于Keepalived实现LVS双主高可用集群_java_21


查看ipvs规则

基于Keepalived实现LVS双主高可用集群_java_22


real server已全部下线,应急服务器上线

基于Keepalived实现LVS双主高可用集群_java_23基于Keepalived实现LVS双主高可用集群_java_24

sorry_server响应成功,至此,基于Keepalived实现LVS双主高可用集群实验完成


The end

基于Keepalived实现LVS双主高可用解决方案就说到这里了,通过实验可以看出使用keepalived构建LVS群集更加简便易用