ตัวสร้าง CUID
สร้าง ID ที่ทนต่อการชนกันได้อย่างรวดเร็วและง่ายดาย
โครงสร้าง CUID
เวลาประทับ:
สุ่ม:
CUID Generator
บทนำ
CUID (Collision-resistant Unique IDentifier) เป็นตัวระบุที่ไม่ซ้ำกันซึ่งออกแบบมาให้ทนต่อการชนกัน, ขยายตัวในแนวนอน, และสามารถเรียงลำดับตามลำดับเวลาได้ CUIDs มีประโยชน์โดยเฉพาะในระบบที่กระจายซึ่งจำเป็นต้องสร้างตัวระบุที่ไม่ซ้ำกันโดยไม่ต้องประสานงานระหว่างโหนด
โครงสร้างของ CUIDs
CUID โดยทั่วไปประกอบด้วยส่วนประกอบต่อไปนี้:
- Timestamp: การแทนค่าของเวลาปัจจุบัน
- Counter: ตัวนับที่เรียงลำดับเพื่อให้แน่ใจว่ามีความไม่ซ้ำกันภายในมิลลิวินาทีเดียวกัน
- Client fingerprint: ตัวระบุที่ไม่ซ้ำกันสำหรับเครื่องหรือกระบวนการที่สร้าง CUID
- Random component: ข้อมูลสุ่มเพิ่มเติมเพื่อลดความน่าจะเป็นของการชนกัน
โครงสร้างที่แน่นอนอาจแตกต่างกันไปขึ้นอยู่กับการใช้งาน CUID แต่ส่วนประกอบเหล่านี้ทำงานร่วมกันเพื่อสร้างตัวระบุที่ไม่ซ้ำกันและสามารถเรียงลำดับได้
นี่คือการแสดงภาพของโครงสร้าง CUID ที่เป็นที่นิยม:
วิธีการสร้าง CUIDs
CUIDs ถูกสร้างขึ้นโดยใช้การรวมกันของส่วนประกอบที่อิงตามเวลาและสุ่ม กระบวนการปกติประกอบด้วย:
- รับค่าของ timestamp ปัจจุบัน
- เพิ่มค่าตัวนับ (ซึ่งจะรีเซ็ตเป็นระยะ ๆ)
- สร้าง client fingerprint (มักทำเพียงครั้งเดียวต่อเซสชันหรือการเริ่มต้นแอปพลิเคชัน)
- เพิ่มข้อมูลสุ่ม
- รวมส่วนประกอบเหล่านี้ในรูปแบบที่เฉพาะเจาะจง
CUID ที่ได้มักจะแสดงเป็นสตริงของตัวอักษรและตัวเลข
ข้อดีและกรณีการใช้งาน
CUIDs มีข้อดีหลายประการเมื่อเปรียบเทียบกับระบบตัวระบุที่ไม่ซ้ำกันอื่น ๆ:
- การทนต่อการชนกัน: การรวมกันของ timestamp, counter, และข้อมูลสุ่มทำให้การชนกันมีความน่าจะเป็นต่ำมาก แม้ในระบบที่กระจาย
- การขยายตัวในแนวนอน: CUIDs สามารถสร้างได้อย่างอิสระบนหลายเครื่องโดยไม่ต้องประสานงาน
- การเรียงลำดับตามลำดับเวลา: ส่วนประกอบ timestamp ช่วยให้สามารถเรียงลำดับ CUIDs ตามเวลา
- เป็นมิตรกับ URL: CUIDs มักประกอบด้วยตัวอักษรที่ปลอดภัยสำหรับ URL
กรณีการใช้งานทั่วไปสำหรับ CUIDs ได้แก่:
- คีย์หลักในฐานข้อมูล
- ระบบที่กระจายซึ่งจำเป็นต้องสร้าง ID ที่ไม่ซ้ำกันข้ามโหนดหลายตัว
- ID เซสชันในแอปพลิเคชันเว็บ
- การติดตามเหตุการณ์ในระบบวิเคราะห์ข้อมูล
- การตั้งชื่อไฟล์หรือทรัพยากรในระบบจัดเก็บข้อมูลคลาวด์
ตัวอย่างโค้ด
นี่คือตัวอย่างการสร้าง CUID ในหลายภาษาโปรแกรม:
// JavaScript (ใช้ไลบรารี 'cuid')
const cuid = require('cuid');
const id = cuid();
console.log(id);
ประวัติและการพัฒนา
CUIDs ถูกพัฒนาขึ้นโดย Eric Elliott ในปี 2012 เป็นวิธีแก้ปัญหาในการสร้างตัวระบุที่ไม่ซ้ำกันในระบบที่กระจาย แนวคิดนี้ได้รับแรงบันดาลใจจากระบบ ID ของ Twitter ที่ชื่อว่า Snowflake แต่ถูกออกแบบมาให้ใช้งานได้ง่ายขึ้นและสามารถใช้ได้ในหลายแพลตฟอร์ม
การพัฒนาของ CUIDs ถูกขับเคลื่อนโดยความต้องการระบบ ID ที่ไม่ซ้ำกันที่เรียบง่ายและทนต่อการชนกัน ซึ่งสามารถทำงานได้ในหลายภาษาโปรแกรมและสภาพแวดล้อม เป้าหมายของ Elliott คือการสร้างระบบที่ง่ายต่อการใช้งาน ไม่ต้องการการประสานงานกลาง และสามารถขยายตัวในแนวนอนได้
ตั้งแต่เริ่มต้น CUID ได้ผ่านการปรับปรุงและพัฒนาหลายครั้ง:
- การใช้งาน CUID ดั้งเดิมมุ่งเน้นที่ความเรียบง่ายและการใช้งานที่ง่าย
- เมื่อการใช้งานเพิ่มขึ้น ชุมชนได้มีส่วนร่วมในการพัฒนาการใช้งานในหลายภาษาโปรแกรม
- ในปี 2021 CUID2 ได้ถูกนำเสนอเพื่อตอบสนองข้อจำกัดบางประการของ CUID ดั้งเดิมและให้ประสิทธิภาพและความทนทานต่อการชนกันที่ดียิ่งขึ้น
- CUID2 ได้ปรับปรุง CUID ดั้งเดิมโดยใช้ตัวสร้างเลขสุ่มที่ปลอดภัยมากขึ้นและเพิ่มความยาวโดยรวมของตัวระบุ
การพัฒนาของ CUIDs สะท้อนถึงความต้องการที่เปลี่ยนแปลงของระบบที่กระจายและความพยายามอย่างต่อเนื่องในการสร้างสมดุลระหว่างความเรียบง่าย ความปลอดภัย และประสิทธิภาพในการสร้างตัวระบุที่ไม่ซ้ำกัน
อ้างอิง
- ที่เก็บ GitHub อย่างเป็นทางการของ CUID
- ข้อกำหนด CUID2
- Elliott, Eric. "การสร้าง ID ที่ไม่ซ้ำกันในสภาพแวดล้อมที่กระจาย." Medium, 2015.
- "ID ที่ทนต่อการชนกันสำหรับระบบที่กระจาย." DZone, 2018.
เครื่องมือสร้าง CUID นี้ช่วยให้คุณสามารถสร้าง CUIDs ได้อย่างรวดเร็วสำหรับโครงการของคุณ เพียงคลิกที่ปุ่ม "สร้าง" เพื่อสร้าง CUID ใหม่ และใช้ปุ่ม "คัดลอก" เพื่อคัดลอกไปยังคลิปบอร์ดของคุณเพื่อใช้งานในแอปพลิเคชันของคุณได้อย่างง่ายดาย