各位 Javaer,你有没有被 UUID 折磨过? 有时候我们用 UUID 当主键,结果数据库索引乱成一锅粥; 有时候我们用自增 ID,又怕分布式系统冲突。

别怕,这次有救了。 2024 年,UUID Version 7(UUIDv7) 正式进入 RFC 标准(RFC 9562),这意味着——

而且在 Java 里,用开源库 uuid-creator 就能轻松搞定。


一、UUIDv7 是啥?

UUID(通用唯一标识符)是一种 128 位的数字,用于在分布式系统中唯一标识信息。UUID Version 7 是 RFC 9562 标准中定义的最新版本,其设计目标是解决早期版本(如 Version 4)的无序性问题,同时保留分布式环境下的唯一性。

与常见的 UUID Version 4(随机生成)相比,Version 7 具有以下核心特点:

  • 时间有序性:将时间戳嵌入 UUID 前 48 位,确保生成的 UUID 按时间顺序递增
  • 高唯一性:结合时间戳、随机数和序列号,避免分布式环境下的冲突
  • 兼容性:保持 128 位长度和标准 UUID 格式(8-4-4-4-12 字符),与现有系统兼容

️ 二、在 Java 里上手:uuid-creator

这个库是 f4b6a3 开发的, 支持所有主流版本(v1、v3、v4、v5、v6、v7、v8), 而且线程安全,轻量无依赖。

安装依赖

Maven:

<dependency>
  <groupId>com.github.f4b6a3</groupId>
  <artifactId>uuid-creator</artifactId>
  <version>5.3.7</version>
</dependency>

Gradle:

implementation 'com.github.f4b6a3:uuid-creator:5.3.7'

三、简单到离谱的用法

生成一个 UUIDv7,只要一行:

import com.github.f4b6a3.uuid.UuidCreator;

public class Demo {
  public static void main(String[] args) {
      var uuid = UuidCreator.getTimeOrderedEpoch();
      System.out.println(uuid);
  }
}

输出示例:

018f91f4-fc71-7d2b-8080-fbb8cc3a56a4

是的,依旧是熟悉的 UUID 样子,但它可以按时间排序。 这意味着——数据库索引更稳、更快、更香。


四、UUIDv7 比旧版本爽在哪?

特性UUIDv4UUIDv1UUIDv7
唯一性 随机唯一 时间唯一 两者兼得
可排序
隐私性(含MAC地址)
性能
标准化(新王)

一句话总结:


五、生产环境最佳实践

1️⃣ 数据库存储推荐

  • MySQL / PostgreSQL 建议使用:

    id BINARY(16) PRIMARY KEY
    
  • CHAR(36) 节省 45% 存储空间。

  • 如果前端要展示,用 uuid.toString() 即可。


2️⃣ 可按时间生成

import java.time.Instant;

var uuid = UuidCreator.getTimeOrderedEpoch(Instant.parse("2025-10-17T12:00:00Z"));
System.out.println(uuid);

这在做“回放数据”、“重建日志”场景时特别有用。


3️⃣ 并发环境放心用

UuidCreator 是线程安全的。 你可以在多线程或分布式场景下放心地调用:

IntStream.range(0, 10).parallel()
    .forEach(i -> System.out.println(UuidCreator.getTimeOrderedEpoch()));

4️⃣ 如果你是分布式系统玩家

UUIDv7 特别适合以下场景:

  • 分布式主键(比 Snowflake 简单)
  • 日志 traceId / spanId
  • Kafka / Redis 消息键
  • 缓存 key / API 请求 ID

六、常见问题 FAQ

Q1:UUIDv7 会不会重复?

不会。 UUIDv7 的随机部分有 74 位,每秒生成上百万个都不用慌。概率上接近零。


Q2:为啥不直接用雪花算法?

  • 雪花算法不是标准,换语言麻烦;
  • 要配置机器号 / 数据中心号;
  • UUIDv7 更轻、更兼容。

Q3:能跟数据库自增 ID 共存吗?

当然。 你可以先在日志、链路追踪中用 UUIDv7, 逐步替代老的自增主键,不需要一次性重构。


七、小结:新一代 ID 的时代来了

总结一句话:

  • 有序可排序
  • 高性能、分布式安全
  • 标准化、跨语言
  • 零配置、即插即用

在 Java 里,只需一个简单的依赖:

UuidCreator.getTimeOrderedEpoch();

就能拥有一个更优雅、更现代的 ID 方案。 如果你的系统还在用 UUIDv4 或雪花算法, 现在就是升级的好时机。


延伸阅读

  • RFC 9562 - UUIDv7 官方标准
  • uuid-creator GitHub
  • ️ Percona Blog - 高效存储 UUID 的方式

最后一句:

本站提供的所有下载资源均来自互联网,仅提供学习交流使用,版权归原作者所有。如需商业使用,请联系原作者获得授权。 如您发现有涉嫌侵权的内容,请联系我们 邮箱:[email protected]