Posted in Redis onApril 03, 2022
场景:针对于分布式并发环境,易出现编码生成重复问题
方案特点:串行操作可避免阻塞加锁,处理效率更高
具体解决方案
private final static String ENTERPRISE_CODE = "enterpriseCode";
@Resource
private 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 串行生成顺序编码的方法实现的文章就介绍到这了,更多相关 Redis 串行生成顺序编码内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!
Redis 串行生成顺序编码的方法实现
- Author -
这个杀手冷死了- Original Sources -
声明:登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述。
Reply on: @reply_date@
@reply_contents@