全局序列
在实现分库分表的情况下,数据库自增主键已无法保证自增主键的全局唯一。
为此, Mycat 提供了全局 sequence,并且提供了包含本地配置和数据库配置等多种实现方式。
本地文件
此方式 Mycat 将 sequence 配置到文件中,当使用到 sequence 中的配置后, Mycat 会更下classpath 中的 sequence_conf.properties
文件中 sequence 当前的值。
- 优点: 本地加载,读取速度快
- 缺点: 抗风险能力差,mycat所在主机宕机后,无法读取本地文件。
数据库方式
利用数据库一个表 来进行计数累加。但是并不是每次生成序列都读写数据库,这样效率太低。
Mycat 会预加载一部分号段到 Mycat
的内存中,这样大部分读写序列都是在内存中完成的
如果内存中的号段用完了 Mycat 会再向数据库要一次。
**问:**那如果 Mycat 崩溃了 ,那内存中的序列岂不是都没了?答:
是的。如果是这样,那么 Mycat 启动后会向数据库申请新的号段,原有号段会弃用。
也就是说如果 Mycat 重启,那么损失是当前的号段没用完的号码,但是不会因此出现主键重复
建立序列脚本
-- dn1 上创建全局序列表
CREATE TABLE MYCAT_SEQUENCE