https://github.com/yitter/idgenerator-go
idgenerator 的 Go 专项引用库。
https://github.com/yitter/idgenerator-go
golang idgenerator snowflake
Last synced: about 1 year ago
JSON representation
idgenerator 的 Go 专项引用库。
- Host: GitHub
- URL: https://github.com/yitter/idgenerator-go
- Owner: yitter
- License: mit
- Created: 2021-03-29T03:18:22.000Z (about 5 years ago)
- Default Branch: main
- Last Pushed: 2023-05-25T15:08:06.000Z (about 3 years ago)
- Last Synced: 2024-06-18T17:12:21.407Z (almost 2 years ago)
- Topics: golang, idgenerator, snowflake
- Language: Go
- Homepage:
- Size: 208 KB
- Stars: 31
- Watchers: 5
- Forks: 8
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# ❄ idgenerator-Go
## 介绍
项目更多介绍参照:https://github.com/yitter/idgenerator
## 引用全局库
```
go get -u -v github.com/yitter/idgenerator-go@v1.3.1
```
## 调用示例(Go)
第1步,**全局** 初始化(应用程序启动时执行一次):
```
// 创建 IdGeneratorOptions 对象,请在构造函数中输入 WorkerId:
var options = idgen.NewIdGeneratorOptions(1)
// options.WorkerIdBitLength = 10 // WorkerIdBitLength 默认值6,支持的 WorkerId 最大值为2^6-1,若 WorkerId 超过64,可设置更大的 WorkerIdBitLength
// ...... 其它参数设置参考 IdGeneratorOptions 定义,一般来说,只要再设置 WorkerIdBitLength (决定 WorkerId 的最大值)。
// 保存参数(必须的操作,否则以上设置都不能生效):
idgen.SetIdGenerator(options)
// 以上初始化过程只需全局一次,且必须在第2步之前设置。
```
第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