问题
主键自增这应该算是一个非常常见的需求,在单机数据库中,这个需求一个 auto_increment
就能实现,但是在数据库集群中,这个需求却变复杂了,因为存在多个数据库实例 ,各自都是主键自增,合在一起就不是主键自增了。
最简单的办法莫过于通过设置主键自增的步长和起始偏移量来处理这个问题。默认情况下,主键自增步长为 1 ,如果我们有三个数据库实例,我们可以将主键自增步长设置为 3 ,这样对于第一个数据库实例而言,主键自增就是 1、4、7、10...,对于第二个数据库实例而言,主键自增就是 2、5、8、11...,对于第三个数据库实例而言,主键自增就是 3、6、9、12....。
MSSQL 可以直接在 SQL 中指定主键的自增步长和起始偏移量,但是 MySQL 则需要修改数据库配置才能实现,因此这里不推荐使用这种方式。
MyCat 作为一个分布式数据库中间,屏蔽了数据库集群的操作,让我们操作数据库集群就像操作单机版数据库一样,对于主键自增,它有自己的方案:
今天我们就先来看看看如何通过 ZK 递增的方式实现主键全局自增。
配置步骤如下:
server.xml
schema.xml
设置主键自增,并且设置主键为 id 。
在 myid.properties 中配置 zookeeper 信息:
sequence_conf.properties
注意,这里表名字要大写。
最后重启 MyCat ,删掉之前创建的表,然后创建新表进行测试即可。