keepalived 实现 LVS 高可用

keepalived 实现 LVS 高可用


keepalived是什么

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


keepalived工作原理

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协议的。


参考文献


实验

主机ip身份
server1172.25.9.1/24keepalived (master)
server4172.25.9.4/24keepalived (backup)
server2172.25.9.2/24httpd
server3172.25.9.3/24httpd

lvs 搭建参考: https://blog.csdn.net/qq_47714288/article/details/120319869

整体步骤

# server1:

## 安装 keepalived
 yum install -y keepalived
## 配置,具体配置,参照server1 keepalived 配置
 vim /etc/keepalived/keepalived.conf
## 启动服务 
 systemctl start keepalived
 ## 查看日志,到当前主机身份,目前 server1 应该是 MASTER。(主机身份与配置文件有关)
  cat keepalived.conf /var/log/messages | grep STATE
 
##  server4 作 备机
 server4 yum install -y keepalived
 scp root@server1:/etc/keepalived/keepalived.conf /etc/keepalived
 ## 配置,具体配置,参照server4 keepalived 配置
 vim /etc/keepalived/keepalived.conf
 ## 启动服务 
 systemctl start keepalived
## 查看日志,到当前主机身份,目前 server4 应该是 BACKUP。(主机身份与配置文件有关)
 cat keepalived.conf /var/log/messages | grep STATE

server1 keepalived 配置

# server1 keepalived 配置
vim /etc/keepalived/keepalived.conf

! Configuration File for keepalived

## 全局定义
global_defs {
   notification_email {
     root@localhost
     #acassen@firewall.loc
     #failover@firewall.loc
     #sysadmin@firewall.loc
   }
   notification_email_from keeplived@localhost
   #smtp_server 192.168.200.1
   smtp_server 127.0.0.1
   smtp_connect_timeout 30
   router_id LVS_DEVEL
   vrrp_skip_check_adv_addr
   #vrrp_strict
   vrrp_garp_interval 0
   vrrp_gna_interval 0
}

## VRRP 检测配置
vrrp_instance VI_1 {
	# 节点身份
    state MASTER
    # interface 节点固有IP(非VIP)的网卡,用来发VRRP包
    interface eth0
    # virtual_router_id 取值在0-255之间,用来区分多个instance的VRRP组播。
    virtual_router_id 51
    # 权重
    priority 100
    # advert_int 发VRRP包的时间间隔,即多久进行一次master选举(可以认为是健康查检时间间隔)。
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    # VIP
    virtual_ipaddress {
    172.25.9.100
    }
}

## 虚拟服务配置
virtual_server 172.25.9.100 80 {
    delay_loop 6
    # lb_algo 调度后端算法
    lb_algo rr
    # lb_kind LVS调度类型NAT/DR/TUN。
    lb_kind DR
    #persistence_timeout 50
    protocol TCP

	# 真正提供服务的机器 
    real_server 172.15.9.2 80 {
        weight 1
        TCP_CHECK {
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
        }
    }
    real_server 172.15.9.3 80 {
        weight 1
        TCP_CHECK {
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
        }
    }
}

server4 keepalived 配置

# server4 keepalived 配置
## 主要改了 主机身份与权重。(state BACKUP ),其它与 server1 一样
vim /etc/keepalived/keepalived.conf

! Configuration File for keepalived

global_defs {
   notification_email {
     root@localhost
     #acassen@firewall.loc
     #failover@firewall.loc
     #sysadmin@firewall.loc
   }
   notification_email_from keeplived@localhost
   #smtp_server 192.168.200.1
   smtp_server 127.0.0.1
   smtp_connect_timeout 30
   router_id LVS_DEVEL
   vrrp_skip_check_adv_addr
   #vrrp_strict
   vrrp_garp_interval 0
   vrrp_gna_interval 0
}

vrrp_instance VI_1 {
    state BACKUP
    interface eth0
    virtual_router_id 51
    priority 50
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
    172.25.9.100
    }
}

virtual_server 172.25.9.100 80 {
    delay_loop 6
    lb_algo rr
    lb_kind DR
    #persistence_timeout 50
    protocol TCP

    real_server 172.15.9.2 80 {
        weight 1
        TCP_CHECK {
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
        }
    }
    real_server 172.15.9.3 80 {
        weight 1
        TCP_CHECK {
            connect_timeout 3
            nb_get_retry 3
            delay_before_retry 3
        }
    }
}


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值