weixin_45634725 2022-12-23 20:04 采纳率: 100%
浏览 17
已结题

两个不同程序共用一把锁,无法控制?

今天在写项目时遇到一个问题,使用springboot的监听器监听数据库的一个字段是否变化,并执行一系列操作。同时主程序运行时也根据这个数据库字段做同样的操作。说是为了防止主程序对数据库操作失败,结果造成的结果是,该操作会执行两次。我想创建一个公共锁,两个程序根据同样的数据拿到一样的锁(锁的类型是string类型,相同数据一样的内容当作锁),这样一个进入,另一个就不会进入,但似乎不支持跨程序锁,有啥方法解决吗?

  • 写回答

3条回答 默认 最新

  • pzzhao 2022-12-23 20:12
    关注

    如果你的服务是多示例部署的可以采用分布式锁,具体通过redis或者ZooKeeper或者数据库来实现,可以根据自己的实际情况来。
    也可以参考这个博客里面分布式锁的实现 https://blog.csdn.net/m0_67645544/article/details/124768505

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 2月13日
  • 已采纳回答 2月5日
  • 创建了问题 12月23日

悬赏问题

  • ¥15 目标检测项目无法读取视频
  • ¥15 GEO datasets中基因芯片数据仅仅提供了normalized signal如何进行差异分析
  • ¥15 小红薯封设备能解决的来
  • ¥100 求采集电商背景音乐的方法
  • ¥15 数学建模竞赛求指导帮助
  • ¥15 STM32控制MAX7219问题求解答
  • ¥20 在本地部署CHATRWKV时遇到了AttributeError: 'str' object has no attribute 'requires_grad'
  • ¥15 vue+element项目中多tag时,切换Tab时iframe套第三方html页面需要实现不刷新
  • ¥50 深度强化学习解决能源调度问题
  • ¥15 一道计算机组成原理问题