#id-generator #snowflake-id #snowflake #algorithm #generation #high #capacity

idgenerator-thin

使用新的雪花漂移算法实现更短ID和更快的生成。核心是缩短ID长度,同时也能拥有非常高的瞬时并发处理能力(50W/0.1s),以及强大的配置能力。

5个版本

0.2.1 2024年4月15日
0.2.0 2023年12月16日
0.1.2 2022年12月7日
0.1.1 2022年12月7日
0.1.0 2022年12月7日

#231 in 并发

Download history 19/week @ 2024-05-19 6/week @ 2024-05-26 7/week @ 2024-06-02 5/week @ 2024-06-09 2/week @ 2024-06-16 74/week @ 2024-06-23 60/week @ 2024-06-30 119/week @ 2024-07-07 19/week @ 2024-07-14 1/week @ 2024-07-21 48/week @ 2024-07-28 37/week @ 2024-08-04 70/week @ 2024-08-11

每月 157 次下载
用于 2 crates

MIT 许可证

20KB
323

idgenerator-thin

修改自 https://github.com/yitter/IdGenerator 的项目。

对源代码中所有的变量名和函数名进行重命名以符合Rust风格,去掉无用的代码,去掉pub extern "C" fn部分。

调用示例(Rust)

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

use idgenerator-thin::{IdGeneratorOptions, YitIdHelper};

// 创建 IdGeneratorOptions 对象,请在构造函数中输入 worker_id:
let options = IdGeneratorOptions::new(1);
// options.worker_id_bit_length = 10; // worker_id_bit_length 默认值6,支持的 worker_id 最大值为2^6-1,若 worker_id 超过64,可设置更大的 wrker_id_bit_length
// ...... 其它参数设置参考 IdGeneratorOptions 定义,一般来说,只要再设置 worker_id_bit_length (决定 worker_id 的最大值)。

// 保存参数(必须的操作,否则以上设置都不能生效):
YitIdHelper::set_id_generator(options);
// 以上初始化过程只需全局一次,且必须在第2步之前设置。

第2步,生成ID:

// 初始化以后,即可在任何需要生成ID的地方,调用以下方法:
let next_id = YitIdHelper::next_id();
println!("next_id: {}", next_id);

依赖项

~1MB
~18K SLoC