[022][数据模块]基于雪花算法的 MyBatis-Plus 主键生成器设计与实现

在线体验各类最新模型,更有模型 免费Token 额度领取!
立即体验
简介: 本项目基于Hutool雪花算法,为MyBatis-Plus定制轻量级分布式主键生成器,含`SnowflakeUtils`(单例+JVM参数配置)、`DefaultIdentifierGenerator`(无缝接入MP)及自动配置类,支持全局有序、高性能ID生成,已落地多个微服务系统。(239字)

[022][数据模块]基于雪花算法的 MyBatis-Plus 主键生成器设计与实现

本项目代码:https://gitee.com/yunjiao-source/tutorials4j

1. 背景

在分布式系统中,数据库主键 ID 的生成是一个常见挑战。传统自增主键在分库分表场景下会失效,而 UUID 虽然全局唯一但占用空间大且无序,影响索引性能。雪花算法(Snowflake)由 Twitter 开源,生成 64 位 Long 型 ID,既能保证全局唯一性,又能保持时间有序,成为分布式 ID 的主流方案。

本文介绍一个在实际项目中整合了 Hutool 雪花算法MyBatis-Plus 的完整解决方案,包含三个核心组件:

  • SnowflakeUtils:雪花算法工具类,提供单例封装和系统属性配置。
  • DefaultIdentifierGenerator:实现 MyBatis-Plus 的 IdentifierGenerator 接口,将雪花 ID 接入 MyBatis-Plus。
  • DataMybatisPlusConfiguration:自动配置类,注册拦截器(分页、乐观锁、防全表更新)并设置全局 ID 生成器。

2. 雪花算法工具类:SnowflakeUtils

2.1 设计目标

  • 提供静态方法 nextId()nextIdStr(),方便业务代码调用。
  • 支持通过 JVM 启动参数动态配置 workerIddatacenterId,适应多节点部署。
  • 单例模式避免重复初始化,保证性能。

2.2 核心代码解析

public class SnowflakeUtils {
   
    public static final String WORKER_ID = "TUTORIALS4J_SNOWFLAKE_WORKER_ID";
    public static final String DATACENTER_ID = "TUTORIALS4J_SNOWFLAKE_DATACENTER_ID";

    private Snowflake snowflake;
    private static SnowflakeUtils INSTANCE;

    private SnowflakeUtils() {
   
        initSnowflake();
    }

    private synchronized void initSnowflake() {
   
        if (snowflake != null) return;
        long datacenterId = getLongProperty(DATACENTER_ID, 1);
        long workerId = getLongProperty(WORKER_ID, 1);
        snowflake = IdUtil.getSnowflake(workerId, datacenterId);
    }

    // 双重检查锁单例
    protected static SnowflakeUtils getInstance() {
    ... }

    public static long nextId() {
   
        return getInstance().snowflake.nextId();
    }

    public static String nextIdStr() {
   
        return getInstance().snowflake.nextIdStr();
    }
}
  • 系统属性读取:例如 -DTUTORIALS4J_SNOWFLAKE_WORKER_ID=2,若未配置则默认 1
  • 异常处理:当属性值非数字时抛出 FrameworkRuntimeException,防止静默失败。
  • Hutool 集成:直接复用 IdUtil.getSnowflake(),减少重复造轮子。

2.3 使用示例

// 生成 long 型 ID
long id = SnowflakeUtils.nextId();

// 生成字符串型 ID(内部仍是雪花算法,非 UUID)
String idStr = SnowflakeUtils.nextIdStr();

3. MyBatis-Plus 标识生成器适配:DefaultIdentifierGenerator

MyBatis-Plus 允许通过 IdentifierGenerator 接口自定义主键生成策略。我们的实现非常简单:

public class DefaultIdentifierGenerator implements IdentifierGenerator {
   
    @Override
    public Number nextId(Object entity) {
   
        return SnowflakeUtils.nextId();
    }

    @Override
    public String nextUUID(Object entity) {
   
        return SnowflakeUtils.nextIdStr();
    }
}
  • nextId() 用于 @TableId(type = IdType.ASSIGN_ID) 且字段类型为数值(Long/Integer)的场景。
  • nextUUID() 用于字段类型为字符串的场景,但注意这里生成的是雪花 ID 的字符串形式,并非真正的 UUID,名称上可优化。

4. MyBatis-Plus 自动配置:DataMybatisPlusConfiguration

该配置类的作用是在 Spring Boot 环境中自动装配 MyBatis-Plus 的核心能力。

4.1 全局 ID 生成器配置

@Bean
public MybatisPlusPropertiesCustomizer defaultIdentifierGeneratorMybatisPlusPropertiesCustomizer() {
   
    return plusProperties -> plusProperties.getGlobalConfig()
            .setIdentifierGenerator(new DefaultIdentifierGenerator());
}

这样所有使用 IdType.ASSIGN_ID 的实体都会自动使用雪花算法生成主键,无需在每个实体类上重复配置。

5. 整体工作流程

  1. Spring Boot 启动 → 加载 DataMybatisPlusConfiguration
  2. 配置全局 ID 生成器 → 将 DefaultIdentifierGenerator 设置到 MyBatis-Plus 全局配置中。
  3. 业务插入数据时 → MyBatis-Plus 检测到主键为 ASSIGN_ID 策略 → 调用 DefaultIdentifierGenerator.nextId()SnowflakeUtils.nextId() → 生成全局唯一有序 ID。

6. 部署配置说明

在分布式部署时,需要为每个节点分配唯一的 workerIddatacenterId。推荐通过环境变量或 JVM 参数注入:

java -DTUTORIALS4J_SNOWFLAKE_WORKER_ID=1 \
     -DTUTORIALS4J_SNOWFLAKE_DATACENTER_ID=1 \
     -jar your-app.jar
  • workerId 范围:0~31(Hutool 默认支持 5 bit,可自定义扩展)
  • datacenterId 范围:0~31
  • 确保所有节点组合唯一,否则可能生成重复 ID。

7. 优缺点分析

7.1 优点

  • 全局唯一且有序:雪花 ID 基于时间戳,天然适合作为数据库主键,利于 B+ 树索引。
  • 高性能:本地生成,无网络开销,单机每秒可达百万级。
  • 配置灵活:通过系统属性控制 worker 和 datacenter,适合容器化部署。

7.2 注意事项

  • 时钟回拨问题:Hutool 的 Snowflake 默认会抛出异常,生产环境需确保 NTP 服务配置正确或使用可容忍回拨的变种。
  • workerId 分配:在 Kubernetes 等动态 IP 环境中,需借助外部分发(如 ZooKeeper、Redis)自动分配 workerId。
  • 字符串 ID 命名nextUUID 方法实际生成雪花 ID 的字符串形式,容易引起误解,可重命名为 nextIdStr

8. 扩展与改进建议

  1. 支持时钟回拨容忍:可参考百度 UidGenerator 或美团 Leaf,增加缓冲机制。
  2. 自动注册 workerId:基于 Redis 或 etcd 实现 workerId 动态分配与心跳续期。
  3. 细化配置:允许通过 application.yml 配置 workerId,而非仅系统属性。

9. 总结

本文提供的三个类构成了一套轻量级、可投入生产的分布式主键解决方案。通过合理的工具封装和框架集成,开发者只需引入依赖并配置 JVM 参数,即可享受到雪花算法带来的高性能与全局有序性,同时还能利用 MyBatis-Plus 的拦截器增强数据库操作安全性。

该方案已在多个微服务项目中稳定运行,适用于中大规模分布式系统的主键生成场景。

目录
相关文章
|
9天前
|
人工智能 JSON 自然语言处理
让教学更智慧:用阿里云百炼工作流,自动生成中小学教材内容#小有可为#有温度的AI
通过可视化工作流编排,将大模型推理能力转化为标准化的教学内容生成引擎。教师只需输入教材标题和适用学段,即可自动获得结构完整、符合课程标准的章节内容,大幅降低备课门槛,助力教育资源均衡化。
484 125
|
18天前
|
Linux 程序员 数据格式
【2026最新】Notepad++下载、安装和使用一篇搞定(附中文版安装包)
Notepad++ 是一款免费开源、轻量高效的 Windows 文本编辑器,支持 C/Python/HTML 等 80+ 语言语法高亮、代码折叠、正则替换、编码转换及插件扩展,专为程序员与文本处理用户打造,完美替代系统记事本。(239字)
|
4天前
|
人工智能 缓存 安全
Claude Code 封号真实原因曝光,这次彻底不装了,直接针对国内开发者的账号下手?
Claude Code 封号潮背后:逆向扒出客户端隐写区域标记,Anthropic 政策收紧叠加 DeepSeek 7 月涨价,国产替代更紧迫。
|
5天前
|
人工智能 安全 Cloud Native
Higress 新发布:AI Gateway 能力增强,Gateway API 及其推理扩展持续打磨
增强 AI 网关能力,持续打磨 Gateway API 及其推理扩展。
325 124
|
13天前
|
机器学习/深度学习 人工智能 调度
🐴 HappyHorse 1.1 现已上线阿里云百炼!快来查收模型使用指南,现在调用享 6 折~
HappyHorse 1.1 是新一代视频生成大模型,全面升级动态表现力、角色一致性、指令遵循、视觉质感与音画协同能力。支持I2V/T2V/R2V三类生成,适配短剧、电商广告、品牌营销等场景,提供高质、流畅、可控的AI视频生产力。
812 5
🐴 HappyHorse 1.1 现已上线阿里云百炼!快来查收模型使用指南,现在调用享 6 折~
|
4天前
|
人工智能 安全 程序员
终于,Claude Code 封号的原因被曝光了!竟然针对中国用户,植入隐形代码?!
通俗易懂地揭秘 Claude Code 封号的手段,分享一些自己对 AI 编程困境的思考,Codex、Cursor、DeepSeek、智谱 GLM、甚至是豆包,都有所行动了
321 1
|
11天前
|
人工智能 定位技术 SEO
我学 GEO 第 15 天:终于知道AI GEO该如何做?
我是暴走的莉莉酱,边旅行边研究AI GEO的数字游民。专注普通人如何提升“AI可见度”——让AI在回答用户问题时准确识别、理解并推荐你。不讲玄学,只做可测、可调、可持续的GEO实践。
460 127

热门文章

最新文章