Java 主鍵生成策略之雪花算法

概述

項目中為了緩解數據庫服務器壓力和提高并發量進行分庫分表,在新增數據時,如果此時按照傳統方式使用數據庫主鍵自增,那么在并發下ID可能會沖突; 使用UUID的話又因其無序會產生頁分裂導致磁盤IO過大使得系統性能降低;? 經過了解雪花算法根據其特點可以解決分布式系統中生成高性能、趨勢遞增、全局唯一ID, 因此項目中使用雪花算法策略生成ID

雪花算法特點

  • 唯一性:?通過結合時間戳、機器ID和序列號,雪花算法可以生成幾乎唯一的ID
  • 高性能:?雪花算法在內存中生成ID,無需訪問數據庫或其他外部服務,因此具有很高的性能
  • 趨勢遞增:?生成的ID是趨勢遞增的,這有助于數據庫索引優化,提高查詢效率
  • 去中心化:?每個節點可以獨立生成ID,無需協調,適合分布式系統
  • 可定制性:?算法中的不同部分(時間戳、機器ID、序列號)可以根據實際需求進行調整
  • 擴展
    • 中心化生成主鍵方案
      • 基于SEQUENCE區間方案
      • 各數據庫按特定步長自增
      • 基于redis生成自增序列
    • 去中心化生成主鍵方案
      • UUID生成無序的唯一ID
      • 雪花算法生成ID

項目最佳實踐

  • 引入第三方依賴
<dependency><groupId>cn.hutool</groupId><artifactId>hutool-core</artifactId>
</dependency>
  • 雪花Id生成工具類
import cn.hutool.core.lang.Snowflake;
import java.util.Random;public class SnowFlakeUtil {// 終端機器ID: 【0-31】private static long workerId = 1; // 數據中心ID: 【0-31】private static long dataCenterId = 1;private volatile static Snowflake snowflake; //雪花對象//靜態塊實現對象初始化static{Random rand=new Random();// 分布式環境下確保為每個實例配置了唯一的workerId和dataCenterId,以避免ID沖突,因此采取隨機方法設置workerId = rand.nextInt(31)+1;//[1,31]內的隨機整數dataCenterId = rand.nextInt(31)+1;//[1,31]內的隨機整數snowflake = getInstance();}// Long型IDpublic static long nextId() {return snowflake.nextId();}// String類型IDpublic static String nextIdStr(){return snowflake.nextIdStr();}// 通過雙重檢測保證Snowflake對象在高并發下對象唯一private static Snowflake getInstance() {if (null == snowflake) {synchronized (SnowFlakeUtil.class) {if (null == snowflake) {snowflake = new Snowflake(workerId, dataCenterId);}}}return snowflake;}// 測試public static void main(String[] args) {System.out.println("IdLong: " + SnowFlakeUtil.nextId()); // IdLong:  1798609085217599488 雪花算法默認LongSystem.out.println("IdStr: " + SnowFlakeUtil.nextIdStr()); // IdStr: 1798609085217599489 某些場景下需要字符串類型}
}

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

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

相關文章

DockerCompose中部署Jenkins(Docker Desktop在windows上數據卷映射)

場景 DockerJenkinsGiteeMaven項目配置jdk、maven、gitee等拉取代碼并自動構建以及遇到的那些坑&#xff1a; DockerJenkinsGiteeMaven項目配置jdk、maven、gitee等拉取代碼并自動構建以及遇到的那些坑_jenkins的安裝以及集成jdkgitmaven 提示警告-CSDN博客 Windows10(家庭版…

AI學習指南機器學習篇-邏輯回歸正則化技術

AI學習指南機器學習篇-邏輯回歸正則化技術 在機器學習領域&#xff0c;邏輯回歸是一種常見的分類算法&#xff0c;它常用于處理二分類問題。在實際的應用中&#xff0c;為了提高模型的泛化能力和降低過擬合風險&#xff0c;邏輯回歸算法通常會使用正則化技術。本文將介紹邏輯回…

待定待定待定

BindingNavigator C# 屬性&#xff08;Property&#xff09; get set StringBuilder https://www.bilibili.com/video/BV15u4y1F72C/ C# 高級數據結構有哪些 List - 動態數組&#xff0c;可以動態增長和縮減&#xff0c;提供快速訪問、添加和刪除元素的功能。Dictionary<TK…

c#vb代碼互轉工具

下載地址&#xff1a; https://download.csdn.net/download/wgxds/88979921

EN 17104-2021室內用熱塑性硬質保護墻板CE認證

室內用熱塑性硬質保護墻板是指由同材質或非均質塑料板制成的&#xff0c;表面有或者沒有裝飾層&#xff0c;用于墻體的保護作用而非起結構作用&#xff0c;通過膠粘劑粘貼安裝。 EN 17104-2021室內用熱塑性硬質保護墻板CE認證項目 認證項目 測試標準 防火 EN 13501-1 揮發…

stm32中如何實現EXTI線 0 ~ 15與對應IO口的配置呢?

STM32的EXTI控制器支持19 個外部中斷/ 事件請求。每個中斷設有狀態位&#xff0c;每個中斷/ 事件都有獨立的觸發和屏蔽設置。 STM32的19個外部中斷對應著19路中斷線&#xff0c;分別是EXTI_Line0-EXTI_Line18&#xff1a; 線0~15&#xff1a;對應外部 IO口的輸入中斷。 線16&…

【MMU】——ARM 一級頁表

文章目錄 一級頁表項即 entry 的格式如下 從上圖可以看出 L1 頁表項有四種可能類型 產生中止異常的故障條目。這可能是預取或數據中止、取決于訪問類型。這實際上表示虛擬地址未映射 bit[1:0] = 00指向 L2 轉換表的條目。這樣就能將 1MB 的內存分頁 bit[1:0] = 01。1MB 段轉換…

STM32遠程更新

1 IAP 概述 1.1 工作原理 在應用中編程&#xff08; IAP &#xff09;是一種在現場通過 MCU 的通信接口&#xff08;例如 UART,USB,CAN 和以太網 等&#xff09;進行固件升級的方式。 當啟動微控制器時&#xff0c;您可以選擇讓它進入 IAP 模式以執行 IAP 代碼&am…

Linux-用戶管理與軟件管理

用戶授權 如果普通用戶需要執行特殊操作&#xff0c;有兩種方法 1、su - root 切換到root賬號進行特殊操作&#xff0c;然后再返回到普通用戶 2、sudo命令 命令&#xff1a;su 優點&#xff1a;使用簡單 缺點&#xff1a;1、root密碼容易泄露&#xff1b;2、普通用…

基于MBD開發汽車軟件

MBD 原理及重要性 模型驅動開發(Model-Based Development,簡稱 MBD)是一種在現代工程領域中日益重要的方法。它的基本原理建立在以模型為核心的理念之上。 MBD 的核心概念包括模型的構建、使用和維護。模型在這里不僅僅是對系統或過程的簡單描述,而是包含了豐富的信息和邏…

04-240606Spark筆記

04-240606Spark筆記 1.行動算子-2 save相關算子: 格式: def saveAsTextFile(path: String): Unit def saveAsObjectFile(path: String): Unit def saveAsSequenceFile(path: String,codec: Option[Class[_ <: CompressionCodec]] None): Unit 例子: val rdd sc.makeR…

【Python報錯】已解決NameError: name ‘Image‘ is not defined

解決Python報錯&#xff1a;NameError: name ‘Image’ is not defined 在使用Python進行圖像處理時&#xff0c;我們經常使用Pillow庫&#xff08;PIL的一個分支&#xff09;。如果你在嘗試創建或處理圖像時遇到了NameError: name Image is not defined的錯誤&#xff0c;這通…

史上最易懂的mysql鎖 、mvvc分析

1 mysql中的鎖類型&#xff1a; 1) 表鎖 表共享鎖(S):表級別的讀鎖&#xff0c;表共享鎖之間是兼容的。 表排他鎖(X): 表級別的寫鎖&#xff0c;表排他鎖和任何鎖(包括表排他鎖)都不兼容(不包括意向鎖)。 意向排他鎖(IX): 獲取行排他鎖之前必須獲取的意向排他鎖&#xff0c;這…

關于python包導入問題的重思考

將頂層目錄直接設置為一個包 像這樣&#xff0c;每一個文件從頂層包開始導入 這樣可以解決我的問題&#xff0c;但是要注意的時&#xff0c;要避免使用出現上下級出現同名包的情況&#xff0c;比如&#xff1a; AutoServer--AutoServer--__init__.py--__init__.py這種情況下…

騰訊云的身份證核驗,找不到這個類

系統接入騰訊云的sdk&#xff0c;Class ‘TencentCloud\Common\Credential’ not found 以下方法核對一下看有沒有做錯&#xff0c;如果沒有需要重啟一下守護一般是能解決問的 這個錯誤表明PHP代碼試圖加載一個名為TencentCloud\Common\Credential的類&#xff0c;但是在指定…

綠聯云NAS一些探索(1):SSH、包管理器探測、安裝docker-compose等

綠聯云NAS一些探索SSH、包管理器探測、安裝docker-compose等 - 文章信息 - Author: 李俊才 (jcLee95) Visit me at CSDN: https://jclee95.blog.csdn.netMy WebSite&#xff1a;http://thispage.tech/Email: 291148484163.com. Shenzhen ChinaAddress of this article:https:…

AI圖書推薦:《如何利用ChatGPT在線賺錢》

這本書《如何利用ChatGPT在線賺錢》&#xff08;$100m ChatGPT_ How To Make Money Online With ChatGPT -- Sharp, Biily -- 2023 &#xff09;主要闡述如何利用ChatGPT這一強大的語言模型工具在互聯網上創造收入。 以下是各章節內容的概要&#xff1a; **引言** - 介紹了Chat…

STM32F103單片機工程移植到航順單片機HK32F103注意事項

一、簡介 作為國內MCU廠商中前三陣營之一的航順芯片&#xff0c;建立了世界首創超低功耗7nA物聯網、萬物互聯核心處理器浩瀚天際10X系列平臺&#xff0c;接受代理商/設計企業/方案商定制低于自主研發十倍以上成本&#xff0c;接近零風險自主品牌產品&#xff0c;芯片設計完成只…

spring整合kafka

原文鏈接&#xff1a;spring整合kafka_spring集成kafka-CSDN博客 1、導入依賴 <dependency><groupId>org.springframework.kafka</groupId><artifactId>spring-kafka</artifactId><version>2.5.10.RELEASE</version> </depende…

Arthas Profiler 事件監控場景介紹

CPU 使用情況 (cpu) 場景描述&#xff1a; 當應用程序響應緩慢或者CPU使用率異常高時&#xff0c;開發者需要找出導致高CPU消耗的具體方法調用。通過監控CPU使用情況&#xff0c;可以識別出那些占用大量CPU時間的熱點方法。 使用Arthas的步驟&#xff1a; 啟動CPU profiler:…