分布式ID方案

目錄

📊?分布式ID方案核心指標對比

🔍?分方案深度解析

???1. UUID (Universally Unique Identifier)

???2. Snowflake (Twitter開源)

???3. 美團Leaf

號段模式

Snowflake模式

🔄?4. 百度UidGenerator

🚀?5. CosId

💎?選型建議



📊?分布式ID方案核心指標對比

方案唯一性有序性吞吐量存儲空間自治性典型場景
UUID全局唯一完全無序300萬/秒128位完全自治會話ID、臨時文件
Snowflake全局唯一趨勢遞增409.6萬/秒64位依賴時鐘訂單ID、日志追蹤
美團Leaf全局唯一本地單調遞增5萬+/秒 (遠程)64位弱依賴DB金融交易、高可用系統
百度Uid全局唯一時間趨勢遞增600萬+/秒64位依賴RingBuffer高并發寫入場景
CosId全局唯一本地嚴格遞增1.27億+/秒64位靈活依賴存儲分庫分表、極致性能需求

🔍?分方案深度解析

???1. UUID (Universally Unique Identifier)
  • 原理:基于MAC地址、時間戳、隨機數拼接后哈希生成128位標識符(如?123e4567-e89b-12d3-a456-426614174000)。

  • 優點:無中心節點、生成簡單、全球唯一。

  • 缺點

    • 長度大:128位存儲效率低,數據庫索引膨脹;

    • 完全無序:導致數據庫插入頻繁頁分裂,性能驟降;

    • 安全隱患:版本1可能泄露MAC地址。

  • 適用場景:臨時令牌、文件命名、非數據庫主鍵場景。

???2. Snowflake (Twitter開源)
  • 官網:https://github.com/twitter/snowflake
  • 原理:64位ID = 時間戳(41位) + 機器ID(10位) + 序列號(12位),實現本地生成。

  • 優點

    • 趨勢遞增:利于數據庫B+樹索引優化;

    • 高性能:單機可達409.6萬ID/秒。

  • 致命問題

    • 時鐘回撥:服務器時間倒退導致ID重復(需人工干預);

    • 機器ID管理難:動態擴縮容時需保障ID唯一性。

  • 改進方向:Leaf-Snowflake 通過ZK緩存workerId弱依賴。

???3. 美團Leaf
  • 官網:Leaf:美團分布式ID生成服務開源 - 美團技術團隊
  • ?源碼地址:https://github.com/Meituan-Dianping/Leaf
號段模式
  • 原理:預分配ID段(如[1,1000]),內存分發,異步更新數據庫。

  • 優化演進

    • 雙Buffer:DB故障時無縫切換備用號段,實現高可用5;

    • 動態Step:根據QPS自動調整號段長度(如QPS↑ → Step×2)。

  • 性能:遠程調用QPS 5W+,TP99 <1ms。

Snowflake模式
  • 解決workerId依賴:ZK分配 + 本地緩存,宕機時降級使用歷史workerId。

🔄?4. 百度UidGenerator
  • 源碼地址:https://github.com/baidu/uid-generator
  • 核心改進

    • RingBuffer預緩存:提前生成ID填充環形隊列,并發取號時無鎖;

    • 借時機制:當前毫秒序號耗盡時,“借用”未來時間戳繼續生成。

  • 局限

    • 默認時間戳僅支持8.7年(41位設計);

    • WorkerId復用策略缺失,擴容受限。

🚀?5. CosId
  • 官網:SegmentId | CosId
  • 源碼地址:https://github.com/Ahoo-Wang/CosId

  • 架構創新

    • SegmentChainId:無鎖號段鏈,基于饑餓狀態動態擴容安全距離,吞吐達1.27億/秒;

    • SnowflakeId增強:解決時鐘回撥、機器號動態分配、分片不均問題;

  • 多存儲支持:JDBC/Redis/ZooKeeper號段分發器,適配不同基礎設施。


💎?選型建議

  • 簡單輕量?→ UUID(非數據庫場景);

  • 有序性與性能平衡?→ Snowflake/Leaf-Snowflake(需解決時鐘問題);

  • 高可用容忍DB故障?→ Leaf號段模式(雙Buffer容災);

  • 極致性能需求?→ CosId(無鎖號段鏈);

  • 長期運行系統?→ 慎用百度Uid(注意時間戳耗盡問題)。

💡?分布式ID的本質是權衡:唯一性、有序性、性能與運維復雜度需結合業務流量、數據庫架構及運維能力綜合決策。新一代方案如CosId通過架構創新顯著提升性能邊界,是分庫分表等高并發場景的優選

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/88756.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/88756.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/88756.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

張量類型轉換

一.前言本章節我們來講解張量的類型轉換&#xff0c;掌握張量的轉換方法&#xff0c;張量的類型轉換也是經常使?的?種操作&#xff0c;是必須掌握的知識點。在本?節&#xff0c;我們主要學習如何將 numpy 數組和 PyTorch Tensor 的轉化?法.二.張量轉換為 numpy 數組使? Te…

JavaEE-初階-多線程初階

概念第一個多線程程序 可以通過查看jdk路徑來找到jdk的控制可以通過jconsole來查看線程。創建線程這是實現多線程的其中一種方法&#xff0c;繼承Thread類&#xff0c;實現run方法&#xff0c;之后實例化繼承了Thread類的MyThread方法&#xff0c;調用start方法&#xff0c;就會…

解釋全連接層的“參數數量”和“計算過程”,保證像看動畫片一樣直觀~

假設場景輸入圖像&#xff1a;一張極小的 灰度圖&#xff08;即 H2,W2&#xff0c;共4個像素&#xff09;&#xff0c;像素值如圖所示&#xff1a;隱藏層&#xff1a;假設隱藏層也是 &#xff08;即 H2,W2&#xff0c;共4個神經元&#xff09;&#xff0c;每個神經元用 ( 表示…

DOM編程實例(不重要,可忽略)

文章目錄 簡介 表格增加刪除&#xff0c;效果如下圖 樣式屬性案例 簡介 DOM---表格添加刪除&#xff0c;樣式屬性案例 表格增加刪除&#xff0c;效果如下圖 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><met…

?Windows API 介紹及核心函數分類表

Windows API 介紹? Windows API&#xff08;Application Programming Interface&#xff09;&#xff0c;也稱為WinAPI&#xff0c;是微軟Windows操作系統的核心編程接口。它提供了一系列函數、消息、數據結構、宏和系統服務&#xff0c;允許開發者創建運行在Windows平臺上的應…

Kubernetes Dashboard UI 部署安裝

K8S 集群環境&#xff1a; Ubuntu 24 / K8S 1.28.21. 推薦使用helm 安裝Kubernetes Dashboardsudo snap install helm --classic2. 部署Kubernetes Dashboard# Add kubernetes-dashboard repository helm repo add kubernetes-dashboard https://kubernetes.github.io/dashboar…

python-enumrate函數

文章目錄基本語法基本用法基本遍歷指定起始索引實際應用場景需要索引的循環創建字典映射處理文件行號與range(len())對比注意事項enumerate()是Python內置函數&#xff0c;用于在遍歷序列&#xff08;如列表、元組或字符串&#xff09;時同時獲取索引和值。基本語法 enumerate…

FPGA通信設計十問

1. FFT有什么用&#xff1f;FFT&#xff08;快速傅里葉變換&#xff09;是離散傅里葉變換&#xff08;DFT&#xff09;的高效實現算法&#xff0c;它的核心作用是快速將信號從時域轉換到頻域&#xff0c;從而簡化信號分析和處理的過程。自然界的信號&#xff08;如聲音、圖像、…

代理模式——Java

代理模式 在Java中代理模式是一種設計模式&#xff0c;是通過代理類來代替原始的對象&#xff0c;可以在不改變原始對象的基礎上&#xff0c;對它進行擴展&#xff08;新增一些新功能&#xff09;。在目標方法的執行的執行前后添加一些自定義的方法。 靜態代理 步驟&#xff1a…

基于Catboost算法的茶葉數據分析及價格預測系統的設計與實現

文章目錄有需要本項目的代碼或文檔以及全部資源&#xff0c;或者部署調試可以私信博主項目介紹數據采集數據預處理數據分析與可視化大屏設計模型構建系統展示每文一語有需要本項目的代碼或文檔以及全部資源&#xff0c;或者部署調試可以私信博主 項目介紹 本研究基于京東官網…

【數據庫基礎 1】MySQL環境部署及基本操作

目錄 一、MySQL部署 1.更新軟件包列表 2.查看合適的安裝包&#xff1a; 3.安裝MySQL 4.啟動數據庫服務并設置開機自啟 5.檢測MySQL當前狀態 6.配置文件修改 二、基本操作指令 1.登陸MySQL 2.創建用戶&修改用戶密碼 3.查看版本 4.退出MySQL 5.停止MySQL 6.數據…

(C++)任務管理系統(正式版)(迭代器)(list列表基礎教程)(STL基礎知識)

源代碼&#xff1a;#include <iostream> #include <list> #include <string>using namespace std;void menu(){cout<<"\n 任務管理系統 "<<endl;cout<<"1.添加普通任務"<<endl;cout<<"2.添加緊急任務…

創建uniapp項目引入uni-id用戶體系使用beforeRegister鉤子創建默認昵稱

需求描述 基于uniCloud開發項目&#xff0c;通常會使用用戶體系&#xff0c;uni-id就是基于uniCloud的用戶體系&#xff0c;滿足常規需要的賬號密碼注冊、登錄&#xff0c;微信登錄等快捷方式&#xff0c;如果使用uni-id自帶的uni-id-pages插件&#xff0c;賬號密碼注冊的話&a…

Opencv---深度學習開發

在OpenCV中進行深度學習開發&#xff0c;主要圍繞其dnn模塊展開&#xff0c;該模塊支持加載預訓練模型、預處理輸入數據、執行推理計算以及解析輸出結果。本文講解基于OpenCV進行深度學習開發的基本流程。 一、準備工作 在開始開發前&#xff0c;需完成環境配置和資源準備&…

【C++11】右值引用詳解

文章目錄前言1. 左、右值的概念1.1 左值1.2 右值1.3 右值引用2. 右值引用的價值和使用場景2.1 左值引用的價值和缺陷2.2 右值引用的價值和使用場景2.3 小結3. 完美轉發4. 類的移動構造和移動賦值前言 在C11之前&#xff0c;面對C11之前出現的臨時對象的傳參構造&#xff0c;都…

如何用自指理解世界

自指即自我指涉&#xff0c;即自己的描述關聯到了自己&#xff0c;典型例子是“這句話是假話”這個悖論。人類對自指的研究由來已久&#xff0c;很多概念、定理都與之相關&#xff0c;由于它的巧妙性&#xff0c;很多學者對其展開了深入研究&#xff0c;并且認為自指是理解宇宙…

Next.js 實戰筆記 2.0:深入 App Router 高階特性與布局解構

Next.js 實戰筆記 2.0&#xff1a;深入 App Router 高階特性與布局解構 上一篇筆記&#xff1a; Next.js 實戰筆記 1.0&#xff1a;架構重構與 App Router 核心機制詳解 上篇筆記主要回顧了一些 Next12 到 Next15 的一些變化&#xff0c;這里繼續學習/復習一些已有或者是新的…

TCP 傳輸時 sk_buff 的 clone 和 unclone

周一有位朋友咨詢個問題&#xff0c;問題本身不重要&#xff0c;但牽扯出的細節卻是非常有趣。 Linux 內核協議棧的 skb 設計非常高效和精巧&#xff0c;多個 skb 可以指向同一塊 data&#xff0c;這就是 clone&#xff0c;當 data 不止一個 skb 指示時&#xff0c;任何一個 s…

【51單片機】51單片機學習筆記-課程簡介

00. 目錄 文章目錄00. 目錄01. 學習哪種類型的單片機02. 學習單片機方法03. 學習單片機硬件設備04. 學習單片機軟件設備05. 學完單片機能做什么06. 附錄01. 學習哪種類型的單片機 單片機的型號那么多&#xff0c;該如何選擇一款合適的進行學習呢&#xff1f;這里給讀者首推的當…

【Docker基礎】Docker端口映射(-p參數)深度解析與實踐指南

目錄 前言 1 Docker網絡基礎 1.1 Docker網絡模型概述 1.2 容器網絡隔離性 2 端口映射基礎 2.1 端口映射概念 2.2 為什么需要端口映射 3 -p參數詳解 3.1 基本語法 3.2 四種映射格式 3.2.1 完整格式 3.2.2 省略宿主機IP 3.2.3 隨機宿主機端口 3.2.4 指定協議類型 …