mycat-05-全局序列

全局序列

在实现分库分表的情况下,数据库自增主键已无法保证自增主键的全局唯一。
为此, Mycat 提供了全局 sequence,并且提供了包含本地配置和数据库配置等多种实现方式。

本地文件

此方式 Mycat 将 sequence 配置到文件中,当使用到 sequence 中的配置后, Mycat 会更下classpath 中的 sequence_conf.properties 文件中 sequence 当前的值。

  • 优点: 本地加载,读取速度快
  • 缺点: 抗风险能力差,mycat所在主机宕机后,无法读取本地文件。

数据库方式

利用数据库一个表 来进行计数累加。但是并不是每次生成序列都读写数据库,这样效率太低。
Mycat 会预加载一部分号段到 Mycat内存中,这样大部分读写序列都是在内存中完成的
如果内存中的号段用完了 Mycat 会再向数据库要一次。

**问:**那如果 Mycat 崩溃了 ,那内存中的序列岂不是都没了?
答:是的。如果是这样,那么 Mycat 启动后会向数据库申请新的号段,原有号段会弃用。
也就是说如果 Mycat 重启,那么损失是当前的号段没用完的号码,但是不会因此出现主键重复

建立序列脚本

-- dn1 上创建全局序列表
CREATE TABLE MYCAT_SEQUENCE 

你可能感兴趣的:(mycat)