snowflake做主键 自增_Snowflake(雪花算法)分布式自增ID算法

本文介绍了Snowflake算法,一种分布式自增ID生成策略。通过解析算法的二进制结构,展示了如何利用时间戳、数据中心ID、工作节点ID和序列号来生成全局唯一ID。还提供了一个具体的SnowflakeIdWorker类的Java实现,用于生成此类ID。
摘要由CSDN通过智能技术生成

/**

* 0 | 0001100 10100010 10111110 10001001 01011100 00 | 10001 | 00001 | 0000 00000000

*

* 0 | 0001100 10100010 10111110 10001001 01011100 00 | 10001 | 00001 | 0000 00000000

* 0 | timestamp |datacenterId| workerId | sequence

* 正数(占位) | 时间戳二进制 | 数据中心ID | 机器ID | 同一机房同一机器相同时间产生的序列

*/

public class SnowflakeIdWorker

{

// 数据中心(机房) id

private long datacenterId;

// 机器ID

private long workerId;

// 同一时间的序列

private long sequence;

/**

* 构造方法

*

* @param workerId 工作ID(机器ID)

* @param datacenterId 数据中心ID(机房ID)

* sequence 从0开始

*/

public SnowflakeIdWorker(long workerId, long datacenterId)

{

this(workerId, datacenterId, 0);

}

/**

* 构造方法

*

* @param workerId 工作ID(机器ID)

* @param datacenterId 数据中心ID(机房ID)

* @param sequence 序列号

*/

public SnowflakeIdWorker(long workerId, long datacenterId, long sequence)

{

// sanity check for workerId and datacenterId

// 机房id和机器id不能超过32,不能小于0

if (workerId > maxWorkerId || workerId < 0)

{

throw new IllegalArgumentException(String.format("worker Id can't be greater than %d or less than 0", maxWorkerId));

}

if (datacenterId > maxDatacente

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值