您好,登錄后才能下訂單哦!
這篇“ Redis串行生成順序編碼的方法怎么實現(xiàn)”文章的知識點大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“ Redis串行生成順序編碼的方法怎么實現(xiàn)”文章吧。
場景:針對于分布式并發(fā)環(huán)境,易出現(xiàn)編碼生成重復問題
方案特點:串行操作可避免阻塞加鎖,處理效率更高
具體解決方案
private final static String ENTERPRISE_CODE = "enterpriseCode"; @Resource private RedisTemplate redisTemplate; private String generateCode() { String code; if (!redisTemplate.hasKey(ENTERPRISE_CODE)) { // Mybatis-Plus 查詢數(shù)據(jù)庫中企業(yè)編碼最大值 EnterprisePO enterprise = enterpriseService.getOne( Wrappers.<EnterprisePO>lambdaQuery() .orderByDesc(EnterprisePO::getCode) .last("limit 1")); // 緩存企業(yè)編碼 if (ObjectUtils.isNotEmpty(enterprise)) { // 如果 key 不存在才 set 避免并發(fā)重復 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 位數(shù),不足六位數(shù)字前面補 0 code = String.format("%06d", number); return code; }
以上就是關(guān)于“ Redis串行生成順序編碼的方法怎么實現(xiàn)”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。