一区二区三区中文国产亚洲_另类视频区第一页_日韩精品免费视频_女人免费视频_国产综合精品久久亚洲

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > UUID和雪花算法的區(qū)別

UUID和雪花算法的區(qū)別

來源:千鋒教育
發(fā)布人:xqq
時間: 2023-11-21 20:37:54 1700570274

一、基本概念

UUID,即通用唯一標(biāo)識符(Universally Unique Identifier),是由一組十六進(jìn)制數(shù)字組成的標(biāo)識符,可以用來在分布式系統(tǒng)中唯一地標(biāo)識某個信息。UUID是一種用于多個計算機(jī)之間的唯一標(biāo)識符,用于指示文件或數(shù)據(jù)庫內(nèi)的唯一對象。

/**
 * 生成UUID
 */
public static String generateUUID() {
    return UUID.randomUUID().toString().replace("-", "");
}

雪花算法,即Snowflake算法,是一種生成ID的算法,它可以保證在分布式系統(tǒng)中生成ID是唯一的。Snowflake算法的核心是一個64位的二進(jìn)制數(shù)字,由以下三部分組成:

1、時間戳(42位):毫秒級時間戳,從開始使用此算法的時間點開始算起,在遞增中產(chǎn)生,最大可用69年;

2、機(jī)器標(biāo)識(10位):可以指定每個節(jié)點的ID從0-1023進(jìn)行編號;

3、序列號(12位):同一毫秒級時間戳下,不同機(jī)器的序列號會依次遞增,最多可以生成4096個ID。

/**
 * 雪花算法
 *
 * @param dataCenterId 數(shù)據(jù)中心ID
 * @param workerId     工作機(jī)器ID
 * @return 分布式ID
 */
public long snowFlake(long dataCenterId, long workerId) {
    long timestamp = System.currentTimeMillis();

    // 時間戳部分
    long timeBits = timestamp - SNOW_FLAKE_EPOCH;

    // 數(shù)據(jù)中心ID部分
    long dataCenterIdBits = dataCenterId << SNOW_FLAKE_DATACENTER_ID_SHIFT;

    // 工作機(jī)器ID部分
    long workerIdBits = workerId << SNOW_FLAKE_WORKER_ID_SHIFT;

    // 組裝分布式ID
    return timeBits | dataCenterIdBits | workerIdBits | sequence;
}

二、唯一性

UUID的唯一性基于產(chǎn)生隨機(jī)性的偽隨機(jī)數(shù)生成器,因此生成的UUID是幾乎不可能重復(fù)的,但也不能完全避免重復(fù)。

相比之下,雪花算法的唯一性更可靠,因為它對時間戳、數(shù)據(jù)中心ID、工作機(jī)器ID和序列號進(jìn)行了組合,可以確保在不同時間戳下不同數(shù)據(jù)中心、不同工作機(jī)器之間產(chǎn)生的ID絕對唯一。但也要注意,如果當(dāng)前工作機(jī)器ID生成的序列號達(dá)到了上限,就會有重復(fù)ID的風(fēng)險。

三、性能

UUID的生成速度相對較快,建議在需要使用anonymize identifier時使用。但是,由于UUID的長度比較長(128位),在使用時需要花費更多的磁盤空間和網(wǎng)絡(luò)帶寬。

雪花算法的生成速度也比較快,但要求系統(tǒng)時鐘準(zhǔn)確無誤,否則就會有ID重復(fù)的問題。此外,在分布式系統(tǒng)中使用時,需要考慮數(shù)據(jù)中心ID和工作機(jī)器ID的分配問題,避免重復(fù)。

四、適用場景

UUID可以在多個分布式系統(tǒng)中保持唯一性,因此廣泛應(yīng)用于匿名或無需長期存儲的系統(tǒng),如會話標(biāo)識符、Cookie ID和游戲中的臨時ID等。

雪花算法適用于分布式系統(tǒng)中的唯一ID生成,可用于唯一訂單號、會員ID和設(shè)備ID等。但是,在多個數(shù)據(jù)中心之間運行時,需要根據(jù)數(shù)據(jù)中心ID和工作機(jī)器ID通過算法配置進(jìn)行規(guī)劃,否則就會產(chǎn)生ID沖突。

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT