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

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

复制代码
mybatis-plus模块

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

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

查看跟踪核心代码

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

查看

复制代码
WorkerNodeEntity 类

给id加上 自增注解

查看

复制代码
WorkerNodeDAO 类

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

如图

最后给获取方法 加上锁

由此解决问题。

相关推荐
y***n61414 小时前
SpringCloud系列教程:微服务的未来(十四)网关登录校验、自定义过滤器GlobalFilter、GatawayFilter
java·spring cloud·微服务
p***s9114 小时前
java进阶1——JVM
java·开发语言·jvm
我是苏苏14 小时前
C#基础:如何创建一个类库并且封装成DLL
开发语言·c#
g***969014 小时前
在Nginx上配置并开启WebDAV服务的完整指南
java·运维·nginx
中工钱袋14 小时前
Spring Task 使用指南
java·spring boot·spring
伯远医学14 小时前
CUT&RUN
java·服务器·网络·人工智能·python·算法·eclipse
CryptoRzz14 小时前
如何快速对接印度股票市场 (NSE/BSE) 数据接口
android·java·开发语言·区块链
一晌小贪欢14 小时前
Python-11 Python作用域与闭包:LEGB规则深度解析
开发语言·python·python基础·python小白·python作用域·python小庄
西峰u14 小时前
Java--面向对象之封装篇!!!
java·开发语言