简单可用好实现的 HA 高可用设计

本文为作者原创,如需转载请注明出处。

1. 实现的功能

    • 一主多备,自动选主
    • 启动记录可查询

2. 前置需求

一台数据库用以记录,如 MySQL、Redis、MongoDB 等。关键是设计中的思想,用啥数据库都行。

3. 设计实现

在数据库中,存一张表,结构如下:

列名说明
id自增数字,nosql的话想实现也不难
instance存放程序实例名,如 app1, app2
startTime实例启动时间
heartBeat心跳时间

 

现以2个实例组成的cluster (心跳为1秒)举例说明:

a. 实例启动

当实例启动时,插入一条记录,例如:

0app12016-08-01 13:00:002016-08-01 13:00:00

当全部实例启动时,例如:

0app12016-08-01 13:00:002016-08-01 13:01:00
1app22016-08-01 13:01:002016-08-01 13:01:00

 

b.选主

原则:一个实例认为自己是主,当且仅当表中heartbeat有效的行中最小id是自己。上面的两个表中都可以看出app1为主。

select min(id) from table where heartbeat > now – heartbeat_interval

c.心跳

每个心跳周期,每个实例自己更新表中的自己的心跳字段:

update table set heartbeat=now where id=myid and heartbeat > now-heartbeat_interval

如果更新结果为0,即失败了,那么说明心跳超时,这时新加入一条记录,例如 app1 超时了:

0app12016-08-01 13:00:002016-08-01 13:58:00
1app22016-08-01 13:01:002016-08-01 14:00:00
2app12016-08-01 14:00:002016-08-01 14:00:00

 

最后,在每个心跳周期结束的时候检查按步骤b自己是否为主,并进行切换。

本文为作者原创,如需转载请注明出处。

转载于:https://www.cnblogs.com/seasonsluo/p/ha_design.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值