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

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

复制代码
mybatis-plus模块

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

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

查看跟踪核心代码

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

查看

复制代码
WorkerNodeEntity 类

给id加上 自增注解

查看

复制代码
WorkerNodeDAO 类

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

如图

最后给获取方法 加上锁

由此解决问题。

相关推荐
峥无7 小时前
MySQL 最全数据类型详解(数值/字符串/日期/枚举集合)
数据库·mysql
十五年专注C++开发7 小时前
ANTLR4: CORBA IDL、C++ 语法文件分析利器
java·开发语言·c++·antlr4
子非衣7 小时前
Java使用Aspose进行Word转PDF时异常卡主问题
java·pdf·word
此生决int7 小时前
Java面向对象进阶精讲:抽象类、接口、内部类与Object类万字详解
java
IT策士7 小时前
Redis 从入门到精通:Redis Sentinel 哨兵
数据库·redis·sentinel
阿维的博客日记7 小时前
‘version‘ must be a constant version but is ‘${revision}‘
java·spring boot·后端
Mortalbreeze7 小时前
C++11 ---- 引用折叠、完美转发、可变模板参数、emplace系列接口
开发语言·c++
星恒随风7 小时前
C++ 内存管理详解:从内存分区、malloc/free 到 new/delete
开发语言·c++·笔记·学习
云器科技7 小时前
螳螂科技:从组装到统一,如何用云器 Lakehouse 完美替代“MC+DW+ADB”三件套?
数据库·数据仓库·人工智能