โ๏ธ Snowflake
Snowflake is a lightweight, efficient Rust library that implements Twitter's Snowflake algorithm for generating unique, time-based IDs. Designed for distributed systems, it provides a scalable solution to ID generation, ensuring no collisions even across multiple workers. Perfect for building high-throughput, reliable systems.
๐ Features
- Unique IDs: Generates 64-bit unique, time-based IDs.
- High Scalability: Designed for distributed systems with multiple workers.
- Efficient: Low-latency ID generation with no contention.
- Customizable: Easy to tweak the bit allocation (worker ID, sequence).
- Rusty: Written in pure Rust for performance and safety.
- Float Safe: The
float-safefeature ensures that the maximum ID is less than 2^53, making it compatible with floating-point number precision.
๐ How It Works
https://en.wikipedia.org/wiki/Snowflake_ID
The Snowflake algorithm generates IDs based on:
- Timestamp (41 bits) - Time in milliseconds since a custom epoch.
- Worker ID (10 bits) - A unique identifier for the worker.
- Sequence (12 bits) - A per-worker counter that resets every millisecond.
The default bit allocation follows the original Snowflake design but can be customized for your specific needs.
๐ Usage
Add Snowflake to your Cargo.toml:
[]
= "1.0.0"
Then, import it in your Rust code:
use ;
Custom Config
You can also set a custom config for ID generation:
use ;
Float-Safe IDs
To ensure that the generated IDs are compatible with floating-point numbers, enable the float-safe feature:
[]
= { = "1", = ["float-safe"] }
See all examples.
๐งช Running Tests
To run the test suite, use:
Benchmark
- Rust version: rustc 1.79.0-nightly (dbce3b43b 2024-04-20)
- Machine setup: Apple M1 Pro 3.23GHz CPU 32GB RAM
test bench_builder ... bench: 26 ns/iter (+/- 1)
test bench_generate ... bench: 233 ns/iter (+/- 29)
test bench_new ... bench: 26 ns/iter (+/- 0)
๐ค Contributing
Contributions are welcome! Feel free to submit issues, feature requests, or pull requests.
๐ License
Snowflake is licensed under the MIT License. See the LICENSE file for more details.