这篇“ Redis串行生成顺序编码的方法怎么实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“ Redis串行生成顺序编码的方法怎么实现”文章吧。
场景:针对于分布式并发环境,易出现编码生成重复问题
方案特点:串行操作可避免阻塞加锁,处理效率更高
具体解决方案
private final static String ENTERPRISE_CODE = "enterpriseCode";@Resourceprivate RedisTemplate redisTemplate;private String generateCode() { String code; if (!redisTemplate.hasKey(ENTERPRISE_CODE)) { // Mybatis-Plus 查询数据库中企业编码最大值 EnterprisePO enterprise = enterpriseService.getOne( Wrappers.<EnterprisePO>lambdaQuery() .orderByDesc(EnterprisePO::getCode) .last("limit 1")); // 缓存企业编码 if (ObjectUtils.isNotEmpty(enterprise)) { // 如果 key 不存在才 set 避免并发重复 set,setIfAbsent() 属于原子操作 redisTemplate.opsForValue().setIfAbsent(ENTERPRISE_CODE, Long.valueOf(enterprise.getCode())); // 也可设置 key 过期时间,此处设置为 1 天 // redisTemplate.opsForValue().setIfAbsent(ENTERPRISE_CODE, Long.valueOf(enterprise.getCode()), 1, TimeUnit.DAYS); } } // 以递增方式缓存最新编码 Long number = redisTemplate.opsForValue().increment(ENTERPRISE_CODE, 1L); // %06d 意为保留 6 位数,不足六位数字前面补 0 code = String.format("%06d", number); return code;}
以上就是关于“ Redis串行生成顺序编码的方法怎么实现”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网行业资讯频道。