#id-generator #snowflake-id #snowflake

idgenerator-thin

Shorter ID and faster generation with a new snowflake drift algorithm. The core is to shorten the ID length, but also can have a very high instantaneous concurrent processing capacity (50W/0.1s), and powerful configuration capacity.

5 releases

0.2.1 Apr 15, 2024
0.2.0 Dec 16, 2023
0.1.2 Dec 7, 2022
0.1.1 Dec 7, 2022
0.1.0 Dec 7, 2022

#257 in Concurrency

Download history 3/week @ 2024-06-13 64/week @ 2024-06-20 50/week @ 2024-06-27 59/week @ 2024-07-04 95/week @ 2024-07-11 6/week @ 2024-07-18 36/week @ 2024-07-25 38/week @ 2024-08-01 55/week @ 2024-08-08 33/week @ 2024-08-15 3/week @ 2024-08-22 12/week @ 2024-08-29 9/week @ 2024-09-05 5/week @ 2024-09-12 24/week @ 2024-09-19 14/week @ 2024-09-26

53 downloads per month
Used in 2 crates

MIT license

20KB
323 lines

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);

Dependencies

~1MB
~18K SLoC