传统的单体架构的时候,我们基本是单库然后业务单表的结构.每个业务表的ID一般我们都是从1增,通过AUTO_INCREMENT=1设置自增起始值,但是在分布式服务架构模式下分库分表的设计,使得多个库或多个表存储相同的业务数据.这种情况根据数据库的自增ID就会产生相同ID的情况,不能保证主键的唯一性. 如上图,如果第一个订单存储在 DB1 上则订单 ID 为1,当一个新订单又入库了存储在 DB2 上订单 ID 也为1.我们系统的架构虽然是分布式的,但是在用户层应是无感知的,重复的订单主键显而易见是不…
大家好,我是树哥. 在复杂的分布式系统中,往往需要对大量的数据和消息进行唯一标识,例如:分库分表的 ID 主键.分布式追踪的请求 ID 等等.于是,设计「分布式 ID 发号器」就成为了一个非常常见的系统设计问题.今天我将带大家一起学习一下,如何设计一个分布式 ID 发号器. 系统诉求 对于业务系统而言,对于全局唯一 ID 一般有如下几个需求: 全局唯一. 生成的 ID 不能重复,这是最基本的要求,否则在分库分表的场景下就会造成主键冲突. 单调递增. 保证下一个 ID 大于上一个 ID,这样可以保…