您好,登錄后才能下訂單哦!
這篇“ Redis串行生成順序編碼的方法怎么實現”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“ Redis串行生成順序編碼的方法怎么實現”文章吧。
場景:針對于分布式并發環境,易出現編碼生成重復問題
方案特點:串行操作可避免阻塞加鎖,處理效率更高
具體解決方案
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串行生成順序編碼的方法怎么實現”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。