一、概念
❄ 什么是雪花算法
SnowFlake算法是Twitter公司出品的开源的分布式id生成算法
其特点为 使用一个64 bit的long型的数字作为全局唯一 id
雪花算法在分布式系统中的应用十分广泛 且引入了时间戳 基本保持自增
❄ 雪花算法字符串各部分的含义
- 第
1位
是符号位 始终为0
(这是因为生成的id都是正数 而在二进制中第一个bit若为0则不为负数) - 后面是
41位
的时间戳 精确到毫秒级
41位的长度可以表示2^41-1个毫秒值 也就是说可以使用69年
时间戳还有一个很重要的作用 可以根据时间进行排序 - 之后的
10位
是机器标识 前5bit是机房id 后5bit是机器id
10位的长度表明该服务最多可以部署在2^10台机器(即1024台机器)上 - 最后
12位
是计数序列号
序列号是一系列的自增id 表示了同一个毫秒内产生的不同id
可以支持同一节点同一毫秒生成多个id 12位的计数序列号支持每个节点每毫秒产生2^12-1(即4096)个ID序号
❄ 生成过程
- 1、若某个服务需要生成一个唯一id 则发送一个请求给部署了SnowFlake算法的系统(前提是该SnowFlake算法系统知道自己所在的机房和机器的编号)
- 2、SnowFlake算法系统接收到该请求后 使用二进制位运算的方式生成一个64bit的long型id 当然 第一个bit是无意义的
- 3、接着41个bit使用当前时间戳(单位为毫秒) 然后的5bit设为该机房的id 剩余5bit设为机器的id
- 4、最后 再判断当前机房的该机器在这一毫秒内是第几个请求 给本次生成id的请求后再累加一个序号 作为id最后的12个bit
至此 就得到了一个64bit的唯一id 这就是雪花算法
二、代码实现
工具类:
public class SnowFlakeUtil {
// 起始时间戳
private final static long START_STMP = 1480166465631L;
// 每部分的位数
private final static long SEQUENCE_BIT = 12; // 序列号占用位数
private final static long MACHINE_BIT = 5; // 机器id占用位数
private final static long DATACENTER_BIT = 5; // 机房id占用位数
// 每部分最大值
private final