精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

簡單實用!利用Redis輕松實現高并發全局ID生成器

數據庫 Redis
今天我就給大家帶來一個神器級的解決方案——Redis 分布式 ID 生成器!配合 SpringBoot3.0,讓你的 ID 生成變得既簡單又高效。

我相信你會經常遇到要生成唯一 ID 的場景,比如標識每次請求、生成一個訂單編號、創建用戶需要創建一個用戶 ID。

謝霸戈:這還不簡單,用 UUID 不就行了。

UUID 確實是個好東西,生成的 ID 全球唯一,但是有兩個致命缺陷。

  • 不是遞增的。MySQL 中索引的數據結構是 B+Tree,這種數據結構的特點是索引樹上的節點的數據是有序的,而如果使用 UUID 作為主鍵,那么每次插入數據時,因為無法保證每次產生的 UUID 有序,所以就會出現新的 UUID 需要插入到索引樹的中間去,這樣可能會頻繁地導致頁分裂,使性能下降。
  • 太占用內存。每個 UUID 由 36 個字符組成,在字符串進行比較時,需要從前往后比較,字符串越長,性能越差。另外字符串越長,占用的內存越大,由于頁的大小是固定的,這樣一個頁上能存放的關鍵字數量就會越少,這樣最終就會導致索引樹的高度越大,在索引搜索的時候,發生的磁盤 IO 次數越多,性能越差。

謝霸戈:那咋辦呢?

別急,今天我就給大家帶來一個神器級的解決方案——Redis 分布式 ID 生成器!配合 SpringBoot3.0,讓你的 ID 生成變得既簡單又高效。

分布式 ID 要滿足什么要求

在進入正文前,先介紹下分布式 ID 應該滿足哪些特性。

分布式 ID 生成器需要滿足以下特性。

  1. 有序性之單調遞增,想要分而治之、二分法查找就必須實現。另外,MySQL 是你們用的最多的數據庫,B+ 樹為了維護 ID 的有序性,就會頻繁的在索引的中間位置插入而挪動后面節點的位置,甚至導致頻繁的頁分裂,這對于性能的影響是極大的。
  2. 全局唯一性,ID 不唯一就會出現主鍵沖突。
  3. 高性能,生成 ID 是高頻操作,如果性能緩慢,系統的整體性能都會受到限制。
  4. 高可用,也就是在給定的時間間隔內,一個系統總的可用時間占的比例。
  5. 存儲空間小,用 MySQL 的 InnoDB B+樹來說,普通索引(非聚集索引)會存儲主鍵值,主鍵越大,每個 Page 頁可以存儲的數據就越少,訪問磁盤 I/O 的次數就會增加。

Redis String 實現分布式 ID

Redis 集群能保證高可用和高性能,為了節省內存,ID 可以使用數字的形式,并且通過遞增的方式來創建新的 ID。

防止重啟數據丟失,你還需要把 Redis AOF 持久化開啟。

MySQL:“開啟 AOF 持久,為了性能設置成 everysec 策略還是有可能丟失一秒的數據,所以你還可以使用一個異步機制將生成的最大 ID 持久化到一個 MySQL。”

好主意,在生成 ID 之后發送一條消息到 MQ 消息隊列中,把值持久化到 MySQL 中。

我們可以使用 Redis String 數據類型來實現,key 用于區分不同業務場景的 ID 生成器,value 存儲 ID。

String 數據類型提供了 INCR 指令,它能把 key 中存儲的數字加 1 并返回客戶端。如果 key 不存在,那么 key 的 value 先被初始化成 0,再執行加 1 操作并返回給客戶端。

Redis,作為一個高性能的內存數據庫,天生就適合處理高并發的場景。它的“單線程”模型更是讓它在處理 ID 生成時如魚得水。

Redis 的操作是原子性的,這就意味著在整個過程中,不會有任何的并發問題出現,從而確保了 ID 的唯一性。

設計思路

設計思路如下圖所示。

圖 2-4

  1. 假設訂單 ID 生成器的 key 是“counter:order”,當應用服務啟動的時候先從數據庫中查詢出最大值 M。執行 EXISTS counter:order 判斷是否存在 key。
  • Redis 中不存在 key “counter:order”,執行 SET counter:order M 將 M 值作寫入 Redis。
  • Redis 中存在 key “counter:order”,值為 K,那么就比較 M 和 K 的值,執行 SET counter:order max(M, N)將最大值寫入 Redis,相等的話就不操作。
  1. 應用服務啟動完成后,每次需要生成 ID 的時候,應用程序就向 Redis 服務器發送 INCR counter:order指令。
  2. 應用程序將獲取到的 ID 值發送到 MQ 消息隊列,消費者監聽隊列把值更新到 MySQL。

SpringBoot 代碼實現

接下來,我們結合 SpringBoot3.0 來打造一個強大且易用的 Redis 分布式 ID 生成器。

首先,我們需要在 SpringBoot 項目中引入 redis 的依賴。在pom.xml文件中添上這行代碼:

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

搞定依賴后,我們得告訴 SpringBoot 怎么連接到 Redis。打開application.yml文件,填上 Redis 的服務地址和端口:

spring:
  application:
    name: redis
  redis:
    host: 127.0.0.1
    port: 6379
    password: magebyte
    timeout: 6000

萬事俱備,只欠東風!接下來,我們編寫一個 ID 生成器工具類。這個工具類負責與 Redis 交互,生成唯一的 ID。這里我們使用 Redis 的INCR命令,它能讓 ID 自增,確保每次獲取的 ID 都是唯一的。

@Component
public class OrderIdGenerator implements InitializingBean {

    private final StringRedisTemplate redisTemplate;

    /**
     * 操作數據庫 dao
     */
    private final IdGeneratorMapper idGeneratorMapper;

    private static final String KEY = "counter:order";

    /**
     * 數據庫中的 ID 值
     */
    private String dbId;

    @Autowired
    public OrderIdGenerator(StringRedisTemplate redisTemplate, IdGeneratorMapper idGeneratorMapper) {
        this.redisTemplate = redisTemplate;
        this.idGeneratorMapper = idGeneratorMapper;
    }

    public Long generateId(String key) {
        return redisTemplate.opsForValue().increment(key, 1);
    }

    @Override
    public void afterPropertiesSet() throws Exception {
        // 從數據庫查詢最大 ID
        this.dbId = idGeneratorMapper.getMaxID(KEY);

        Boolean hasKey = redisTemplate.hasKey(KEY);
        if (Boolean.TRUE.equals(hasKey)) {
            // key 存在,比較 dbId 與 redisValue,取出最大值
            String redisValue = redisTemplate.opsForValue().get(KEY);
            String targetValue = max(this.dbId, redisValue);
        } else {

自定義 ID 規則

不過呢,光有唯一的 ID 還不夠,我們還得讓它更符合業務的實際需求。比如訂單編號吧,我們可能希望它的格式是ORD-20240528-0001,其中ORD是業務標識,20240528是日期,0001是當天的序號。

public String generateCustomId(String key, String prefix, String datePattern) {
    long sequence = redisTemplate.opsForValue().increment(key, 1);
    return String.format("%s-%s-%04d", prefix, new SimpleDateFormat(datePattern).format(new Date()), sequence);
}

那具體怎么用呢?讓我們在業務代碼中一探究竟!想象一下,在一個電商系統中,當一個新的訂單如流星般劃過天際,我們迫不及待地想要一個獨一無二的 ID 來標記它時——很簡單,只需調用我們的generateCustomId方法,傳入訂單相關的參數即可。

@Service
public class OrderService {
    private final RedisIdGenerator idGenerator;

    @Autowired
    public OrderService(RedisIdGenerator idGenerator) {
        this.idGenerator = idativeIdGenerator;
    }

    public Order createOrder(OrderRequest request) {
        String orderId = idGenerator.generateCustomId("order:id", "ORD", "yyyyMMdd");
        Order order = new Order();
        order.setId(orderId);
        // 其他業務邏輯...
        return order;
    }
}
責任編輯:姜華 來源: 碼哥跳動
相關推薦

2022-12-29 08:43:54

IDredis

2017-07-01 16:02:39

分布式ID生成器

2019-12-27 10:00:34

開源技術 軟件

2022-07-25 10:27:36

背景生成器工具前端

2024-01-26 08:28:41

工單號生成器場景

2022-03-03 08:30:41

GeneratorES6函數

2025-03-11 08:50:00

CASID分布式

2022-02-15 10:30:58

UUID

2015-08-25 11:07:58

2025-01-23 08:36:27

CSS開發工具

2020-08-21 13:15:29

開發技能代碼

2011-12-23 13:42:05

JavaScript

2010-09-07 16:31:17

SQL語句insert

2021-04-22 21:15:38

Generator函數生成器

2025-01-06 09:06:04

JavaScriptWeb 開發Generators

2017-03-20 17:49:21

Java Web模板代碼

2016-01-08 10:55:31

PHP莫斯電碼生成器

2016-12-21 10:55:55

PHP莫斯電碼生成器

2024-11-01 15:51:06

2021-07-14 07:17:37

Springboot分布式UIDGenerato
點贊
收藏

51CTO技術棧公眾號

午夜av一区二区| 国产一区二区不卡在线| 国产亚洲欧洲在线| 色一情一区二区| av在线免费观看网址| 成人一区二区三区在线观看| 欧美亚洲在线观看| 久草福利资源在线| 欧美91在线| 欧美私模裸体表演在线观看| 伊人再见免费在线观看高清版| 人妻va精品va欧美va| 日日夜夜精品免费视频| 欧美成人在线网站| 四虎国产精品成人免费入口| 亚洲国产综合在线观看| 亚洲国产中文字幕在线视频综合| 欧美午夜精品理论片a级大开眼界 欧美午夜精品久久久久免费视 | 国产伦精品一区二区三区视频青涩 | 欧美精品免费视频| 777精品久无码人妻蜜桃| 日本在线视频站| 91偷拍与自偷拍精品| 91系列在线观看| 中文字幕一区二区三区四区欧美| 欧美淫片网站| 在线视频国产日韩| 亚洲中文字幕无码av| www.久久爱.com| 在线观看免费成人| a在线视频观看| 激情网站在线| 亚洲免费观看高清完整版在线观看 | 久久久久久尹人网香蕉| 四虎永久免费地址| 精品免费视频| 亚洲男人的天堂网站| 国内精品免费视频| 蜜桃精品视频| 欧美久久久久久久久久| 国产精品乱码久久久久| 欧美久久天堂| 午夜欧美一区二区三区在线播放| 老司机午夜网站| 日本中文字幕在线观看| 国产精品私人影院| 日本电影一区二区三区| 青青草视频免费在线观看| 国产成人精品三级麻豆| 91视频九色网站| 国产精品视频一二区| 美女视频黄免费的久久 | 欧美午夜小视频| 日本精品600av| 一区二区不卡在线播放| 日本a级片在线观看| 毛片在线看网站| 中文字幕在线不卡| 中文字幕一区二区三区有限公司| 2017亚洲天堂1024| 国产精品久线观看视频| 在线视频91| 黄色在线论坛| 一级女性全黄久久生活片免费| 无码人妻aⅴ一区二区三区日本| 日本美女在线中文版| 最新国产精品久久精品| 桥本有菜av在线| 伊人春色在线观看| 亚洲一区二区3| 九九爱精品视频| 天堂√8在线中文| 色欲综合视频天天天| 日本成人在线免费视频| 成人在线免费av| 欧美一区二区三区免费视频| av在线天堂网| 国产成人精品毛片| 国产很黄免费观看久久| 国产精品日韩一区二区免费视频| 蜜臀av在线观看| 久久久久国产免费免费 | 人妖粗暴刺激videos呻吟| 国偷自产视频一区二区久| 亚洲成色777777女色窝| 熟女俱乐部一区二区| 日韩黄色大片| 欧美丰满少妇xxxxx| 羞羞影院体验区| 免费人成在线不卡| eeuss一区二区三区| 视频三区在线观看| 中文字幕高清一区| 老司机激情视频| 欧美三级网址| 日韩一区二区免费高清| a天堂视频在线观看| 精品国精品国产自在久国产应用| 插插插亚洲综合网| 国产区一区二区三| 国产在线播放一区三区四| 国产精品免费在线播放| 成人在线观看网站| 亚洲一区中文在线| 日韩一级免费在线观看| 蜜桃精品视频| 中文字幕久精品免费视频| 久久久www成人免费毛片| 噜噜噜在线观看免费视频日韩| 成人免费淫片视频软件| 日韩a在线观看| 日韩美女视频一区二区 | 日韩精品亚洲视频| 裸体武打性艳史| 久久一二三四| 国产一区在线免费| 黄网站在线免费看| 91国偷自产一区二区三区观看 | 好吊妞视频这里有精品| 日韩在线观看免费高清| 在线永久看片免费的视频| 国产成人免费在线观看不卡| 五码日韩精品一区二区三区视频| 美女精品导航| 91精品欧美久久久久久动漫| 丰满少妇高潮一区二区| 亚洲视频免费| 95av在线视频| 老司机在线看片网av| 91黄视频在线观看| 强迫凌虐淫辱の牝奴在线观看| 91精品99| 91久久精品美女高潮| 成年人视频免费在线观看| 欧美日韩中文字幕综合视频| 亚洲国产精品第一页| 影音先锋日韩在线| 91精品美女在线| 888av在线| 欧美在线观看视频一区二区| 精品人妻一区二区三区日产乱码卜| 亚洲一区在线| 91免费版黄色| 操你啦在线视频| 91精品婷婷国产综合久久竹菊| 1024手机在线观看你懂的| 天堂在线一区二区| 欧美午夜免费| 成人交换视频| 中文字幕综合在线| 亚洲中文字幕一区二区| 中文字幕在线免费不卡| 国产性生活一级片| 久久久久国产精品| 亚洲综合色av| 黄色成人在线网| 亚洲成人精品视频在线观看| 免费一级特黄特色大片| 99热这里都是精品| 黄色片一级视频| 精品国产99| 国产裸体写真av一区二区 | 亚洲a视频在线观看| 亚洲一二三四区| 好吊色视频一区二区三区| 亚洲黄色免费| 欧美日韩高清在线一区| 日韩一区精品| 久久九九免费视频| 精品人妻一区二区三区浪潮在线 | 欧美h片在线观看| 国产中文一区二区三区| 97在线免费视频观看| 51vv免费精品视频一区二区| 久久久免费精品视频| 婷婷丁香一区二区三区| 日韩欧美在线视频日韩欧美在线视频| 亚洲av成人无码久久精品| 久99久精品视频免费观看| 日韩视频一二三| 日韩大胆成人| 国产一区私人高清影院| 乱插在线www| 亚洲图片欧美日产| 国产有码在线观看| 五月婷婷综合网| 美国黄色特级片| 国产传媒久久文化传媒| 激情网站五月天| 欧美成人精品| 欧美第一黄网| 免费一级欧美片在线观看网站| 97人洗澡人人免费公开视频碰碰碰| 国产综合在线观看| 欧美一级久久久| 国产91精品看黄网站在线观看| 国产精品二三区| 给我看免费高清在线观看| 理论片日本一区| 青青草精品视频在线| 日韩精品久久久久久久电影99爱| 91视频99| 88xx成人网| 98精品国产高清在线xxxx天堂| 亚洲搞黄视频| 日韩精品在线观看一区| 国产美女精品视频国产| 色综合久久综合网97色综合| 欧美又粗又大又长| 欧美国产国产综合| 变态另类丨国产精品| 国产成+人+日韩+欧美+亚洲| 国产小视频精品| 亚洲欧美网站| 无码专区aaaaaa免费视频| 91一区二区| 色大师av一区二区三区| 啪啪激情综合网| 国产精品久久国产精品| 亚洲国产aⅴ精品一区二区三区| 国产成人久久久| 欧美xxxhd| 久久久久久中文| av免费在线网站| 久久精品国产精品| porn视频在线观看| 亚洲视频一区二区| 天堂а在线中文在线无限看推荐| 精品欧美乱码久久久久久1区2区| 91好色先生tv| 欧洲精品在线观看| 99久久久久久久久| 富二代精品短视频| 欧美a∨亚洲欧美亚洲| 亚洲国产cao| 久久免费公开视频| 一区二区免费视频| 久草中文在线视频| 一个色妞综合视频在线观看| 黄视频网站免费看| 最新不卡av在线| 在线观看亚洲网站| 自拍偷拍欧美激情| 中文字幕亚洲欧美日韩| 综合久久久久久久| 中文字幕av免费在线观看| 亚洲免费资源在线播放| 亚洲一级生活片| 一区二区三区在线播| 欧美日韩一级大片| 亚洲成人av电影| 国产成人亚洲精品自产在线| 精品成人国产在线观看男人呻吟| 日韩成人一区二区三区| 欧美日韩中文字幕综合视频| 成年人视频在线免费看| 日本精品免费观看高清观看| 免费又黄又爽又猛大片午夜| 欧美午夜精品久久久久久孕妇 | 中文字幕无码日韩专区免费| 综合欧美亚洲日本| 久热精品在线观看| 高跟丝袜欧美一区| 男操女视频网站| 这里只有精品99re| 午夜精品久久久久久久99热黄桃| 亚洲精品在线免费观看视频| 少妇高潮久久久| 亚洲区在线播放| 男人的天堂在线视频免费观看| 久久亚洲精品毛片| 成人在线免费观看黄色| 欧美一区二区三区四区在线| abab456成人免费网址| 成人精品在线视频| 久本草在线中文字幕亚洲| 欧美欧美一区二区| 欧美国产小视频| 精品人妻大屁股白浆无码| 一区二区三区精品视频在线观看| 欧美日韩在线播放一区二区| 精品理论电影在线| 97在线免费视频观看| 亚洲欧美成人综合| 国产精品区在线| 不卡的看片网站| youjizz亚洲女人| 亚洲综合视频网| 亚洲精品久久久久久久蜜桃| 欧美一区二区三区婷婷月色| 亚洲AV成人无码一二三区在线| 中文字幕九色91在线| 福利小视频在线| 国产成人综合精品在线| 伊人精品综合| 日韩在线观看电影完整版高清免费| 欧美黄色免费| 亚洲五月天综合| 成人国产精品免费| 精品一区二区三孕妇视频| 亚洲妇熟xx妇色黄| 怡红院男人的天堂| 亚洲精品久久久久久久久| 免费av不卡| 国产成人高清激情视频在线观看 | 欧美精品一区二区视频| 欧美成人精品| 蜜臀一区二区三区精品免费视频| 97精品视频在线观看自产线路二| 天天天天天天天天操| 欧美在线观看视频一区二区三区| 色呦呦视频在线| 欧美黑人视频一区| 91麻豆精品国产91久久久更新资源速度超快| 久久婷婷人人澡人人喊人人爽| 我不卡伦不卡影院| 成年人免费大片| 91丨porny丨最新| 久视频在线观看| 日韩欧美资源站| 精品视频在线一区二区| 国产精品福利久久久| 婷婷国产精品| 99在线精品免费视频| 国产成人综合视频| 中文字幕五月天| 欧美日韩精品一区二区三区| 可以直接在线观看的av| 午夜精品一区二区三区在线视频 | 国产黄色精品| 青青草国产精品| 久久久久看片| 成人免费网站黄| 欧美色道久久88综合亚洲精品| 黄色www视频| 午夜精品久久久久久久白皮肤| 亚洲日本va| www.夜夜爱| 成人精品视频.| 精品一级少妇久久久久久久| 欧美大肚乱孕交hd孕妇| 在线看福利影| 成人av网站观看| 精品电影一区| 在线观看国产免费视频 | 羞羞色院91蜜桃| 在线电影av不卡网址| 九九热这里有精品| 亚洲欧洲精品在线观看| 久久爱www久久做| 爱爱视频免费在线观看| 日韩视频123| 国产极品人妖在线观看| 精品一区久久久| 噜噜噜久久亚洲精品国产品小说| 欧美做受高潮6| 欧美日韩国产一级二级| 成人影欧美片| 国产精品一区二区三区在线| 日韩视频三区| 亚洲午夜久久久久久久国产| 欧美日韩一区二区三区四区五区| 欧美成人二区| 国产精品乱码| 久久人人超碰| 欧美性生交大片| 欧美mv和日韩mv国产网站| av免费不卡国产观看| 免费在线观看91| 久久精品免费看| 久久久久久久久久综合 | 国产精品一区二区三区不卡 | 久久久久久无码精品人妻一区二区| 一区二区三区精品视频| 亚洲 美腿 欧美 偷拍| 国产精品成人播放| 91精品啪在线观看国产18| www.555国产精品免费| 狠狠色狠狠色综合日日小说| av在线电影院| 成人av中文| 美国三级日本三级久久99| 久久一二三四区| 一区二区三区在线播放欧美| 日韩一区二区三区在线看| 国产 福利 在线| |精品福利一区二区三区| 日本人妻熟妇久久久久久| 国产精品com| 影音先锋亚洲一区| 欧美一区二区三区观看| 亚洲福利在线看| 日韩福利影视| 国产免费黄色av| 亚洲精品欧美二区三区中文字幕| 国产小视频免费观看| 国产精品免费一区| 亚洲精品影视| 国产一区二区播放| 国产亚洲欧美日韩精品|