里面不仅包括java还有c、c++、python等多语言ID生成器;
其中的算法是作者基于雪花算法实现的雪花漂移算法,在提高产生ID的并发量的同时减少了生成时间,
其ID的组成依旧沿用雪花算法的组成方式:
大家可以去github上面仔细阅读,下载源码去自己去看看
那么如何使用呢?
这里以springboot项目为例:
引入maven包:
<dependency>
<groupId>com.github.yitter</groupId>
<artifactId>yitter-idgenerator</artifactId>
<version>1.0.6</version>
</dependency>
使用:第一步:
全局初始化(应用程序启动时执行一次)
// 创建 IdGeneratorOptions 对象,可在构造函数中输入 WorkerId:
IdGeneratorOptions options = new IdGeneratorOptions(Your_Unique_Worker_Id);
// options.WorkerIdBitLength = 10; // 默认值6,限定 WorkerId 最大值为2^6-1,即默认最多支持64个节点。
// options.SeqBitLength = 6; // 默认值6,限制每毫秒生成的ID个数。若生成速度超过5万个/秒,建议加大 SeqBitLength 到 10。
// options.BaseTime = Your_Base_Time; // 如果要兼容老系统的雪花算法,此处应设置为老系统的BaseTime。
// ...... 其它参数参考 IdGeneratorOptions 定义。
// 保存参数(务必调用,否则参数设置不生效):
YitIdHelper.setIdGenerator(options);
// 以上过程只需全局一次,且应在生成ID之前完成。
第二步:
生成ID
// 初始化后,在任何需要生成ID的地方,调用以下方法:
long newId = YitIdHelper.nextId();
如有侵权,告知速删!