Keepalived详解

1、keepalived是什么

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

2、keepalived工作原理

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

3、Keepalived模块

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

4、keepalived的配置文件

keepalived只有一个配置文件keepalived.conf,里面主要包括以下几个配置区域,分别是global_defs、static_ipaddress、static_routes、vrrp_script、vrrp_instance和virtual_server。
如下:

#准备两台虚拟机
分别yum install  keepalived  ##先安装Keepalived
#对配置文件进行修改
[root@server-13 /test]# cat /etc/keepalived/keepalived.conf 
global_defs {
   router_id mha  #命名
}

vrrp_instance   mha1 {
    state MASTER                ## 另外一个主机设置为 BACKUP 
    interface ens33              ##网卡
    virtual_router_id  51       ##切换组中的成员,id要保持一致。
    priority 100                   ##两个主机优先级一样即可实现轮询
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
        192.168.10.88   ##虚拟ip
    }   
}
[root@server-13 /test]#keepalived  -D   #启动服务
[root@server-13 /test]#ps axu   ##查看进程。
[root@server-13 /test]#ip a   ##查看虚拟ip在哪里
[root@server-13 /test]#killall keepalived  ##杀死服务,虚拟ip会漂移到另一台虚拟机

总结:Keepalived可以配合其他一起使用,实现服务器之间的相互转换,当客户端访问服务器的虚拟ip地址时,即使一台服务器出现故障,Keepalived可以立马切换至另一台服务器,避免单点故障的产生!在实际工作环境中也很有用处!

借鉴了另一位作者的一部分内容,在此特意感谢!
转载:http://outofmemory.cn/wiki/keepalived-configuration

你可能感兴趣的:(linux)