keepalived的nopreempt选项

vrrp_script区域

 

用来做健康检查的,当时检查失败时会将vrrp_instance的priority减少相应的值。

几个配置项的解释:

vrrp_script chk_http_port {

    script "

    interval 1

    weight -10

}

以上意思是如果script中的指令执行失败(或返回值不等于0),那么相应的vrrp_instance的优先级会减少10个点。

 

nopreempt允许一个priority比较低的节点作为master,即使有priority更高的节点启动。通常情况下,利用keepalived做热备,

其中一台设置为master,一台设置为backup。当master出现异常后,backup自动切换为master。当backup成为master后,master恢复正常后

会再次抢占成为master,导致不必要的主备切换。因此可以将两台keepalived初始状态均配置为backup,设置不同的优先级,

优先级高的设置nopreempt解决异常恢复后再次抢占的问题。

首先nopreemt必须在state为BACKUP的节点上才生效(因为是BACKUP节点决定是否来成为MASTER的),其次要实现类似于关闭auto failback的功能需要将所有节点的state都设置为BACKUP,或者将master节点的priority设置的比BACKUP低。我个人推荐使用将所有

节点的state都设置成BACKUP并且都加上nopreempt选项,这样就完成了关于autofailback功能,当想手动将某节点切换为MASTER时只

需去掉该节点的nopreempt选项并且将priority改的比其他节点大,然后重新加载配置文件即可(等MASTER切过来之后再将配置文件改回去再reload一下)。

 

当使用track_script时可以不用加nopreempt,只需要加上preempt_delay 5,这里的间隔时间要大于vrrp_script中定义的时长。

 

preempt_delay master启动多久之后进行接管资源(VIP/Route信息等),并提是没有nopreempt选项。

 

 

启动成功后看是否有3个keepalived的进程 ps -ef | grep keepalived:

其中一个是父进程,负责监控其子进程。一个是vrrp子进程,另外一个是checkers子进程。

你可能感兴趣的:(高可用,分布式,运维)