type
status
date
slug
summary
tags
category
icon
为了生成一个符合要求的分布式全局ID,我们可以使用
StringRedisTemplate
来实现。这个ID由三部分组成:- 符号位(1 bit):始终为0,表示正数。
- 时间戳(31 bit):表示从某个起始时间点(例如2023-01-01 00:00:00)到现在的秒数。
- 序列号(32 bit):用于在同一秒内生成不同的ID。
实现步骤
- 计算时间戳:从某个起始时间点到现在的秒数。
- 生成序列号:使用Redis的原子递增操作来生成序列号。
- 组合ID:将时间戳和序列号组合成一个64位的长整型数字。
代码实现
代码解释
- EPOCH:起始时间点,例如2023-01-01 00:00:00,转换为秒数。
- SEQUENCE_KEY_PREFIX:Redis中存储序列号的键前缀。
- generateId 方法:
- currentTimeSec:从起始时间点到现在的秒数。
- sequenceKey:根据当前时间戳生成的Redis键。
- sequence:使用
opsForValue().increment
方法生成序列号,确保在同一秒内生成不同的ID。
- 序列号溢出处理:如果序列号达到最大值(2^32 - 1),则重置为0,并设置键在1秒后过期。
- 组合ID:将时间戳左移32位,然后与序列号进行按位或操作,生成最终的64位ID。
测试代码
- 作者:BOB
- 链接:https://hb2001.vercel.app/article/147678cd-7808-8045-aaa5-cde2f78d4f80
- 声明:本文采用 CC BY-NC-SA 4.0 许可协议,转载请注明出处。