从此
📄文章 #️⃣专题 🌐酷站 👨‍💻技术 📺 📱

🏠 » 📄文章 » 内容

 欢迎来访!

UUID版本竟有这么多?唯一标识符适用场景

🕗2024-07-16👁️6

通常,当我们有多个编号版本时,数字越大的版本越新,并且被认为更好。相比之下,UUID 有 8 个版本(v1 到 v8),它们各不相同,并且都在标准中定义。

在这里,我将从高层次解释它们是什么,并链接到 RFC 的特定部分,以防您需要更多详细信息。

UUID 版本 1 (v1)由时间戳、单调计数器和 MAC 地址生成。
UUID 版本 2 (v2)保留用于没有已知详细信息的安全 ID 2。
UUID 版本 3 (v3)是根据您提供的一些数据的 MD5 哈希值生成的。RFC 建议将 DNS 和 URL 列为数据候选对象。
UUID 版本 4 (v4)完全由随机数据生成。这大概就是大多数人对 UUID 的看法和理解。
UUID 版本 5 (v5)是根据您提供的一些数据的 SHA1 哈希值生成的。与 v3 一样,RFC 建议将 DNS 或 URL 作为候选。
UUID 版本 6 (v6)由时间戳、单调计数器和 MAC 地址生成。这些数据与版本 1 相同,但顺序有所改变,因此排序时将按创建时间排序。
UUID 版本 7 (v7)是由时间戳和随机数据生成的。
UUID 版本 8(v8)是完全自定义的(除了所有版本都包含的必需版本/变体字段)。

 

什么时候应该使用它们?


有八个不同的版本,您应该使用哪个?有几个常见的用例决定您应该使用哪个,有些已经被其他版本取代。

您通常会在 v4 或 v7 之间进行选择。有时也会选择 v5 或 v8。

如果您只需要一个随机 ID,请使用 v4。 这是一个不错的默认选择。
如果您在需要排序的上下文中使用 ID,请使用 v7。例如,如果您使用 UUID 作为数据库键,请考虑使用 v7。
如果您想要在 UUID 中使用自己的数据,则使用 v5 或 v8,但通常情况下,您会知道是否需要它。

 

其它的呢?


根据 RFC,v7 是对 v1 和 v6 的改进,如果可能的话,应该优先使用它们。所以你通常不会想要 v1 或 v6。如果你确实想要其中之一,你可以使用 v6。
v2 是为未指定的安全事项保留的。如果您正在使用这些,您可能无法告诉我或任何其他人,并且您可能不会阅读这篇文章来了解有关它们的更多信息。
v3 已被 v5 取代,后者使用更强大的哈希。您可能知道是否需要它。