1
0
mirror of synced 2025-11-06 03:20:55 +08:00
Files
2023-06-20 20:54:57 +08:00
..
2023-06-20 20:54:57 +08:00
2022-10-02 19:39:29 +08:00
2023-05-25 23:23:51 +08:00

❄ idgenerator-Go

介绍

项目更多介绍参照:https://github.com/yitter/idgenerator

引用全局库

go get -u -v github.com/yitter/idgenerator-go

调用示例Go

第1步全局 初始化(应用程序启动时执行一次):

// 创建 IdGeneratorOptions 对象,可在构造函数中输入 WorkerId
var options = idgen.NewIdGeneratorOptions(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 定义。

// 保存参数(务必调用,否则参数设置不生效):
idgen.SetIdGenerator(options)

// 以上过程只需全局一次且应在生成ID之前完成。

第2步生成ID

// 初始化后在任何需要生成ID的地方调用以下方法
var newId = idgen.NextId()

关于Go环境

1.SDK: go1.17

2.启用 Go-Modules

go env -w GO111MODULE=on

# Next *ONLY* for China-Users:
go env -w GOPROXY=https://goproxy.cn,https://goproxy.io,direct

代码贡献者(按时间顺序)

guoyahao | amuluowin | houseme