重复借还款重复划扣解决思路,借款锁人,还款锁单

重复借款问题

解决方案:redis锁

Talk is cheap,Show me the code 别BB,给我直接展示代码

生成核心代码

String creatOrderKey = "Loan:" + loanCreateReqDto.getUserId(); //锁用户id

Long currentTime = System.currentTimeMillis();

//userId放入redis false key之前已经存在,已加锁 true 不存在 放入成功 加锁成功

boolean lock = redisTemplate.opsForValue().setIfAbsent(creatOrderKey, currentTime);

try {

if (lock) {//加锁成功

//校验各种信息,生成借款订单

logger.info("借款:结果:resultDto:{}",JSON.toJSONString(resultDto));

} else {//加锁失败

logger.info("任务已在进行中,,稍后再试");

}

} catch (Exception e) {

logger.info("借款异常 ", e);

} finally {

if (lock) {

redisTemplate.delete(creatOrderKey);

logger.info("任务结束,释放锁!");

} else {

logger.info("(当前线程)没有获取到锁,无需释放锁!");

Long createTime = (Long) redisTemplate.opsForValue().get(creatOrderKey);

Long nowTime = System.currentTimeMillis();

Long time = (nowTime - createTime) / 1000;

if (time > 30l) {

logger.info("超过30秒,释放锁!");

redisTemplate.delete(creatOrderKey);

}

}

}

还款重复划扣

锁单,代码逻辑同上

String orderno = repayVo.getOrderNo();

String key = "repay:" + orderno;

Long currentTime = System.currentTimeMillis();

boolean lock = redisTemplate.opsForValue().setIfAbsent(key, currentTime);

try {

if (lock) {

logger.info("还款逻辑处理 );

return xx;

}else{

logger.info("还款业务进行中");

return xx;

}

}catch (Exception e){

logger.error("还款:系统异常",e);

return xx;

}finally {

if (lock) {

redisTemplate.delete(key);

logger.info("还款:任务结束,释放锁!");

} else {

logger.info("还款:没有获取到锁,无需释放锁!");

Long createTime = (Long) redisTemplate.opsForValue().get(key);

Long nowTime = System.currentTimeMillis();

Long time = (nowTime - createTime) / 1000;

if (time > 20l) {

redisTemplate.delete(key);

logger.info("还款:超过20秒,释放锁!");

}

}

}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章