1.pacemaker
Pacemaker 是一款开源的高可用资源管理软件,适合大集群或者小集群。 Pacemaker 由Novell支持,SLES HAE就是用Pacemaker来管理集群,并且Pacemaker 得到了 来自Redhat,Linbit等公司的支持。 Pacemaker是Heartbeat 3.0的crm,它可以使用所有的Heartbeat的资源脚本,升级无忧。
Pacemaker是一个集群资源管理者。他用资源级别的监测和恢复来保证集群服务(aka. 资源)的最 大可用性。它可以用你所擅长的基础组件(Corosync或者是Heartbeat)来实现通信和关系管理。
关键特性:
监测并恢复节点和服务级别的故障存储无关,并不需要共享存储资源无关,任何能用脚本控制的 资源都可以作为服务支持使用STONITH来保证数据一致性。支持大型或者小型的集群clusters 支持 quorate(法定人数) 或 resource(资源) 驱动的集群支持任何的 冗余配置自动同步各个节 点的配置文件可以设定集群范围内的ordering, colocation and anti-colocation支持高级的 服务模式
2.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协议的。
VRRP 工作机制
在一个VRRP虚拟路由器中,有多台物理的VRRP路由器,但是这多台的物理的机器并不能同时工作, 而是由一台称为MASTER的负责路由工作,其它的都是BACKUP,MASTER并非一成不变,VRRP让每个 VRRP路由器参与竞选,最终获胜的就是MASTER。MASTER拥有一些特权,比如,拥有虚拟路由器的 IP地址,我们的主机就是用这个IP地址作为静态路由的。拥有特权的MASTER要负责转发发送给网关 地址的包和响应ARP请求。
3.区别
- 安装配置不同
从安装、配置、使用、维护等角度上对比,Keepalived都比Heartbeat要简单得多,Keepalived 只有1个安装文件、1个配置文件,配置文件也简单很多
协议不同
Keepalived使用的vrrp协议方式进行通信和选举,虚拟路由冗余协议Virtual Router Redundancy Protocol Heartbeat是基于主机或网络的服务的高可用方式 ,使用心跳进行通信和选举,Heartbeat除了 走网络外,还可以通过串口通信,貌似更可靠
应用场景不同
keepalived目的是模拟路由器的双机,lvs的高可用建议用keepavlived heartbeat目的是用户service的双机 ,业务的高可用用heartbeat
功能不同
Keepalived主要用于集群倒换,基本没有管理功能 Heartbeat虽然复杂,但功能更强大,配套工具更全,适合做大型集群管理
使用方式基本类似
如果要基于两者设计高可用方案,最终都要根据业务需要写自定义的脚本,Keepalived的脚本没 有任何约束,随便怎么写都可以;Heartbeat的脚本有约束,即要支持service start/stop/restart 这种方式,而且Heartbeart提供了很多默认脚本,简单的绑定ip,启动apache等操作都已经有了