ژنراتور ULID
ULID تولید شده:
ساختار ULID
زمان (10 کاراکتر)
تصادفی بودن (16 کاراکتر)
تولید ULID
مقدمه
ULID (شناسه یکتا و قابل مرتبسازی بهصورت لغتنامهای جهانی) یک شناسه یکتا است که زمان را با دادههای تصادفی ترکیب میکند تا یک رشته ۲۶ کاراکتری ایجاد کند. ULIDها بهگونهای طراحی شدهاند که قابل مرتبسازی بهصورت لغتنامهای باشند و در عین حال درجه بالایی از یکتایی و تصادفی بودن را حفظ کنند.
ساختار یک ULID
یک ULID از دو بخش اصلی تشکیل شده است:
- زمان (۱۰ کاراکتر): ۱۰ کاراکتر اول نمایانگر زمان به میلیثانیه از زمان Unix Epoch (۱۹۷۰-۰۱-۰۱) است.
- تصادفی بودن (۱۶ کاراکتر): ۱۶ کاراکتر باقیمانده با استفاده از دادههای تصادفی امن رمزنگاری شده تولید میشوند.
رشته ۲۶ کاراکتری نتیجه با استفاده از الفبای base32 کراکفورد (۰-۹ و A-Z، بهجز I، L، O و U) رمزگذاری میشود.
فرمول
ULID با استفاده از مراحل زیر تولید میشود:
- تولید یک زمان ۴۸ بیتی (میلیثانیه از زمان Unix Epoch).
- تولید ۸۰ بیت داده تصادفی امن رمزنگاری شده.
- رمزگذاری ۱۲۸ بیت ترکیبی با استفاده از رمزگذاری base32 کراکفورد.
محاسبه
تولیدکننده ULID مراحل زیر را انجام میدهد:
- دریافت زمان فعلی به میلیثانیه.
- تولید ۱۰ بایت تصادفی (۸۰ بیت) با استفاده از یک تولیدکننده عدد تصادفی امن رمزنگاری شده.
- ترکیب زمان و دادههای تصادفی به یک عدد ۱۲۸ بیتی.
- رمزگذاری عدد ۱۲۸ بیتی با استفاده از رمزگذاری base32 کراکفورد.
موارد استفاده
ULIDها در سناریوهای مختلف مفید هستند، از جمله:
- کلیدهای پایگاه داده: ULIDها میتوانند بهعنوان شناسههای یکتا برای رکوردهای پایگاه داده استفاده شوند و یکتایی و قابلیت مرتبسازی را تضمین کنند.
- سیستمهای توزیعشده: در محیطهای توزیعشده، ULIDها میتوانند بدون هماهنگی بین گرهها تولید شوند.
- ثبت و ردیابی: ULIDها میتوانند برای برچسبگذاری ورودیهای لاگ یا ردیابی رویدادها استفاده شوند و شناسهای یکتا و قابل مرتبسازی ارائه دهند.
- شناسههای مناسب برای URL: ULIDها ایمن برای URL هستند و میتوانند بهعنوان شناسه در URLها در برنامههای وب استفاده شوند.
جایگزینها
در حالی که ULIDها چندمنظوره هستند، سیستمهای شناسه یکتای دیگری نیز وجود دارند که باید در نظر گرفته شوند:
- UUID (شناسه یکتا جهانی): یک شناسه ۱۲۸ بیتی که شامل یک مؤلفه زمان نمیشود.
- KSUID (شناسه یکتا قابل مرتبسازی K): مشابه ULID اما با رمزگذاری زمان متفاوت.
- شناسه Snowflake: سیستم تولید شناسه یکتای توزیعشده توییتر که شامل یک زمان و شناسه کارگر است.
تاریخچه
ULIDها در سال ۲۰۱۶ توسط علیزین فیرستا بهعنوان یک جایگزین برای UUIDها معرفی شدند. آنها برای رفع برخی محدودیتهای UUIDها طراحی شدهاند، بهویژه از نظر قابلیت مرتبسازی و خوانایی. مشخصات ULID از زمان معرفی آن ثابت مانده است و پیادهسازیهای مختلفی در زبانهای برنامهنویسی مختلف موجود است.
مثالها
در اینجا چند مثال کد برای تولید ULID در زبانهای برنامهنویسی مختلف آورده شده است:
// پیادهسازی JavaScript
function generateULID() {
const timestamp = Date.now().toString(36).padStart(10, '0');
const randomness = crypto.getRandomValues(new Uint8Array(16))
.reduce((acc, byte) => acc + byte.toString(36).padStart(2, '0'), '');
return (timestamp + randomness).toUpperCase();
}
console.log(generateULID());
این مثالها نحوه تولید ULIDها را در JavaScript، Python و Java نشان میدهند. شما میتوانید این توابع را به نیازهای خاص خود تطبیق دهید یا آنها را در سیستمهای بزرگتر که به شناسههای یکتا نیاز دارند، ادغام کنید.
منابع
- "مشخصات ULID." GitHub، https://github.com/ulid/spec. دسترسی در ۲ اوت ۲۰۲۴.
- "رمزگذاری Base32 کراکفورد." رمزگذاری Base32، http://www.crockford.com/base32.html. دسترسی در ۲ اوت ۲۰۲۴.
- "UUID در مقابل ULID." Stack Overflow، https://stackoverflow.com/questions/54222235/uuid-vs-ulid. دسترسی در ۲ اوت ۲۰۲۴.