flash 好的网站,上海网站建设 缔客,企业做网站哪家公司好,下载百度免费版文章目录 Redis - 全局ID生成器 RedisIdWorker一、引言二、实现原理三、代码实现代码说明 四、使用示例示例说明 五、总结 Redis - 全局ID生成器 RedisIdWorker 一、引言
在分布式系统中#xff0c;生成全局唯一ID是一个常见的需求。传统的自增ID生成方式在分布式环境下容易出… 文章目录 Redis - 全局ID生成器 RedisIdWorker一、引言二、实现原理三、代码实现代码说明 四、使用示例示例说明 五、总结 Redis - 全局ID生成器 RedisIdWorker 一、引言
在分布式系统中生成全局唯一ID是一个常见的需求。传统的自增ID生成方式在分布式环境下容易出现冲突而UUID虽然可以保证唯一性但长度较长且不够紧凑。RedisIdWorker是一种基于Redis实现的全局ID生成器它结合了时间戳和自增序列号能够在分布式环境中高效地生成唯一且有序的ID。
二、实现原理
RedisIdWorker的核心思想是利用Redis的自增特性和时间戳来生成唯一且有序的ID。其生成的ID由两部分组成
时间戳部分使用当前时间戳减去一个起始时间戳例如某个特定日期的时间戳得到一个相对时间戳。时间戳部分通常占用31位以秒为单位这样可以保证在69年内生成的ID是唯一的。自增序列号部分使用Redis的INCR命令生成一个自增序列号确保在相同的时间戳下ID是唯一的。序列号部分通常占用32位这意味着每秒可以生成2^32个不同的ID。
在具体实现中时间戳部分和自增序列号部分通过位运算组合在一起。时间戳部分左移32位然后与序列号部分进行按位或操作最终生成一个64位的全局唯一ID。这种设计不仅保证了ID的唯一性还确保了ID的递增性有利于数据库索引的创建。
这种实现方式充分利用了Redis的原子操作特性确保在高并发环境下生成的ID仍然是唯一的。同时由于时间戳和序列号的结合生成的ID具有一定的规律性但又不会直接暴露业务逻辑。
三、代码实现
以下是RedisIdWorker的Java代码实现
java复制
Component
public class RedisIdWorker {// 开始时间戳例如2022年1月1日private static final long BEGIN_TIMESTAMP 1640995200L;// 序列号的位数private static final int COUNT_BITS 32;private StringRedisTemplate stringRedisTemplate;public RedisIdWorker(StringRedisTemplate stringRedisTemplate) {this.stringRedisTemplate stringRedisTemplate;}// 获取下一个自动生成的IDpublic long nextId(String keyPrefix) {// 1. 生成时间戳LocalDateTime now LocalDateTime.now();long nowSecond now.toEpochSecond(ZoneOffset.UTC);long timestamp nowSecond - BEGIN_TIMESTAMP;// 2. 获取当前日期用于生成keyString date now.format(DateTimeFormatter.ofPattern(yyyy:MM:dd));// 3. 获取自增序列号long count stringRedisTemplate.opsForValue().increment(incr: keyPrefix : date);// 4. 拼接并返回IDreturn timestamp COUNT_BITS | count;}
}代码说明
时间戳部分通过LocalDateTime获取当前时间戳并减去起始时间戳BEGIN_TIMESTAMP。自增序列号部分使用StringRedisTemplate的increment方法为每个日期生成一个自增序列号。ID拼接将时间戳左移32位然后与序列号进行按位或操作生成最终的ID。
四、使用示例
以下是一个简单的使用示例
java复制
SpringBootTest
public class RedisIdWorkerTest {Resourceprivate RedisIdWorker redisIdWorker;Testpublic void testIdWorker() {// 生成订单IDlong orderId redisIdWorker.nextId(order);System.out.println(Generated Order ID: orderId);// 生成用户IDlong userId redisIdWorker.nextId(user);System.out.println(Generated User ID: userId);}
}示例说明
nextId方法接收一个keyPrefix参数用于区分不同类型的ID例如订单ID、用户ID等。每次调用nextId方法都会生成一个唯一的ID并且由于时间戳和自增序列号的结合生成的ID是严格递增的。
五、总结
RedisIdWorker是一种简单高效的全局ID生成器特别适用于分布式系统。它通过结合时间戳和自增序列号利用Redis的原子操作保证了ID的唯一性和有序性。在实际项目中可以根据业务需求调整时间戳的起始值和序列号的位数以满足不同的场景。 版权声明本博客内容为原创转载请保留原文链接及作者信息。
参考文章
[Redis - 全局ID生成器 RedisIdWorker - CSDN博客][Redis - 全局ID生成器 RedisIdWorker本文介绍了分布式系统中的全局ID生成器RedisIdWorke - 掘金]