高可用-脑裂:
两个机器都认为自己是主机,争抢资源。
1、机器之间是物理线发送心跳,故可冗余备份;
2、发现心跳线断开就锁住共享磁盘;
3、仲裁机制,心跳线断开之后两个节点去ping参考ip,不通的放弃竞争并且重启释放共享资源
ID生成器(趋势递增 + 高可用):
1、VIP + keepalive作为id-service,底层双主库做写操作,数据库中保存当前id最大值
2、类似snowflake算法,64位的id,使用毫秒数 + 业务线 + 机器号 + 毫秒内序列号等字段填充
MySQL双主库(写库高可用):
1、并发引起的,同步时发现数据冲突,同步失败。两库初始值不同,步长相同。
2、上游业务层生成趋势递增的ID
3、双主库是两个库均提供写操作,可以单点写入 + VIP + keepalive
4、3中极限情况(master写入数据但还未同步到slave时,master挂掉,直接切到没有最近写入那条数据的slave中),用脚本内网DNS检测master,如果挂掉,设定一个同步时间x秒,之后再接管IP,保证延时高可用