Java基于队列实现ID分发器

这个逻辑是仿照Leaf 写的ID分发器,因为本身系统中的id是通过表的方式生成的,使用类似mybatisselectKey 方式生成的

 

less

代码解读

复制代码

@Insert({ "UPDATE sequence SET id=CASE WHEN id+1>max THEN min ELSE id+1 END WHERE stub=#{name}" }) @SelectKey(statement = "SELECT id FROM sequence WHERE stub=#{name}", keyProperty = "id", before = false, resultType = Long.class )

但是这样势必会产生锁竞争,在高并发的场景下Mysql的CPU会由于等待锁,去查询死锁可能,使用率飙升,并发大的时候可能会宕机。所以就相当利用预生成id的方式来获取id leaf是一个完整的id生成策略,如果是新系统的话完全可以使用,但是我们的系统中还存在很多原来的获取id的地方,所以利用Queue来存储生成的id,为了防止id使用完毕的生成逻辑耗时,用两个Queue来切换。 整体代码如下

这边整理了一份核心面试笔记包括了:Java面试、Spring、JVM、MyBatis、Redis、MySQL、并发编程、微服务、Linux、Springboot、SpringCloud、MQ、Kafka 面试专题

 需要全套面试笔记的【点击此处即可】免费获取

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: Java消息队列可以解决人数等待的问题。通过将消息放入消息队列中,可以实现异步通信,允许用户将消息放入队列,但不立即处理它们。这样可以避免人数等待,即使有大量的消息需要处理,也可以按照自己的需求逐个处理。\[1\]此外,Java消息队列还提供了解决重复发送消息的机制。每条消息都会生成一个全局唯一的消息ID,通过这个ID可以判断消息是否重复发送,并决定是否将消息落地到数据库中。这样可以保证一条消息只能一次落地到数据库,避免重复处理。\[2\]另外,可以利用Java消息队列的高级特性,如Message Groups,来实现负载均衡的机制。通过设置消息的JMSXGroupID属性,可以将消息分发给不同的消费者,实现消息的均衡处理。\[3\]因此,Java消息队列可以有效地解决人数等待的问题,提高系统的并发性能和可靠性。 #### 引用[.reference_title] - *1* [JAVA消息中间件/消息队列](https://blog.csdn.net/qq_52093708/article/details/131096741)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Java面试——消息队列](https://blog.csdn.net/zhengzhaoyang122/article/details/115796146)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值