雪花算法 集群uid重复问题 uid-generator-spring-boot-starter

1、在生成环境 在某个业务使用该插件生成uid,由于业务整合了

复制代码
mybatis-plus模块

2、该业务是分部署集群部署以及使用的多线程获取uid,使用中发现唯一建冲突,生成的uid有重复。

然后查看日志发现 workerId 始终为0 怀疑是生成workerId出了问题。

查看跟踪核心代码

发现 是保存响应的代码有问题,没有响应id

查看

复制代码
WorkerNodeEntity 类

给id加上 自增注解

查看

复制代码
WorkerNodeDAO 类

复制代码
addWorkerNode方法 
复制代码
@Options注解加上
复制代码
keyProperty参数

如图

最后给获取方法 加上锁

由此解决问题。

相关推荐
jakeswang几秒前
全解MySQL之死锁问题分析、事务隔离与锁机制的底层原理剖析
数据库·mysql
weixin_456904274 分钟前
Spring Boot 用户管理系统
java·spring boot·后端
趁你还年轻_4 分钟前
异步编程CompletionService
java
DKPT8 分钟前
Java内存区域与内存溢出
java·开发语言·jvm·笔记·学习
sibylyue13 分钟前
Guava中常用的工具类
java·guava
Heliotrope_Sun14 分钟前
Redis
数据库·redis·缓存
奔跑吧邓邓子16 分钟前
【Java实战㉞】从0到1:Spring Boot Web开发与接口设计实战
java·spring boot·实战·web开发·接口设计
一成码农22 分钟前
MySQL问题7
数据库·mysql
吃饭最爱25 分钟前
JUnit技术的核心和用法
数据库·oracle·sqlserver
专注API从业者25 分钟前
Python/Java 代码示例:手把手教程调用 1688 API 获取商品详情实时数据
java·linux·数据库·python