A.-? 2022-08-09 13:26 采纳率: 68.4%
浏览 390
已结题

redisson没有释放锁,造成死锁

redisson没有释放锁,造成死锁
boolean isLock = redissonUtil.tryLock(lockKey, TimeUnit.SECONDS, 3, -1);

        try {
            //result = multiLock.tryLock(3, TimeUnit.SECONDS);
            if (isLock) {
                log.info("method monitAffirmOrder agtId:{} 线程ID:{} 取到锁--时间:{}", agtId, Thread.currentThread().getId(), DateUtil.parseDateToStr(new Date(), DateUtil.DATE_TIME_FORMAT_YYYY_MM_DD_HH_MI_SS));


                AgtOrder agtOrder = agtOrderService.getAgtOrder(model.getAgtOrderNo());
                MchOrder mchOrder = mchOrderService.getMchOrder(agtOrder.getMchOrderNo());
                //agtOrder.setOperator(getOperator());
                agtOrder.setOperator("监控确认");
                agtOrder.setRemark(model.getRemark());

                saResult = iorderService.orderCallback20220624(agtOrder, mchOrder, agtConfList);
                if (200 == saResult.getCode() && null != agtOrder.getNotifyStatus() && agtOrder.getNotifyStatus() != 1) {
                    mchIpConfService.updateMchIpOrder(mchOrder);
                    agtAccountService.processAgtAcByAccId(agtOrder.getAccId());// 码商收款成功之后,对收款账户进行处理
                    SaResult res = orderService.autoCallback(agtOrder, mchOrder);
                    if (200 == res.getCode()) {
                        return SaResult.ok();
                    } else {
                        return res;
                    }
                }
            } else {
                return SaResult.get(3457, "服务繁忙, 稍后再试", "服务繁忙, 稍后再试");
            }
        } catch (Exception e) {
            saResult = SaResult.get(3457, "affirmOrder error", e);
            log.error("affirmOrder error ", e);
        } finally {
            if (isLock) {
                log.info("method monitAffirmOrder  agtId:{} 线程ID:{} 释放锁--时间:{}", agtId, Thread.currentThread().getId(), DateUtil.parseDateToStr(new Date(), DateUtil.DATE_TIME_FORMAT_YYYY_MM_DD_HH_MI_SS));
                redissonUtil.unlock(lockKey);
                log.info("method monitAffirmOrder  agtId:{} 线程ID:{} 释放锁成功--时间:{}", agtId, Thread.currentThread().getId(), DateUtil.parseDateToStr(new Date(), DateUtil.DATE_TIME_FORMAT_YYYY_MM_DD_HH_MI_SS));

            }
        }

现在这个key一直在redis自动续命。

img


该key最后一次获取锁日志

img


后续的就没有释放锁的日志,也没有异常日志

有人知道什么情况吗?redisson版本3.12.5 单机版
解决这个死锁问题
  • 写回答

2条回答 默认 最新

  • 柏油 2022-08-10 09:54
    关注

    1、看门狗的存在是为了防止锁在业务逻辑完成之前释放
    2、问题中描述看门狗一直在给锁续期,应该是没有执行 unlock 逻辑
    3、检查下业务逻辑是不是有 bug

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

报告相同问题?

问题事件

  • 系统已结题 8月21日
  • 已采纳回答 8月13日
  • 请提交代码 8月9日
  • 创建了问题 8月9日

悬赏问题

  • ¥15 esp8266控制共阳极wrgb灯板无法关闭所有led灯
  • ¥100 python读取速度问题
  • ¥15 stm32f407使用DMA问题
  • ¥15 您好 这个API接口该怎么弄 网站搭建好了 API也有 现在就不知道该怎么填写API 不知道怎么用
  • ¥88 用uniapp写一个多端的程序,用到高德地图,用高德的JSAPI吗?
  • ¥20 关于#c++#的问题:水果店管理系统
  • ¥30 dbLinq最新版linq sqlite
  • ¥20 对D盘进行分盘之前没有将visual studio2022卸载掉,现在该如何下载回来
  • ¥15 完成虚拟机环境配置,还有安装kettle
  • ¥15 有人会搭建生鲜配送自营+平台的管理系统吗