91在线观看视频-91在线观看视频-91在线观看免费视频-91在线观看免费-欧美第二页-欧美第1页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

為什么不選擇UUID?ULID才是更好的選擇!

數(shù)據(jù)分析與開發(fā) ? 來(lái)源:CSDN ? 2024-01-17 11:28 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

ULID:Universally Unique Lexicographically Sortable Identifier(通用唯一詞典分類標(biāo)識(shí)符)

UUID:Universally Unique Identifier(通用唯一標(biāo)識(shí)符)

為什么不選擇UUID

UUID 目前有 5 個(gè)版本:

版本1:在許多環(huán)境中是不切實(shí)際的,因?yàn)樗枰L問(wèn)唯一的,穩(wěn)定的MAC地址,容易被攻擊;

版本2:將版本 1 的時(shí)間戳前四位換為 POSIX 的 UID 或 GID,問(wèn)題同上;

版本3:基于 MD5 哈希算法生成,生成隨機(jī)分布的ID需要唯一的種子,這可能導(dǎo)致許多數(shù)據(jù)結(jié)構(gòu)碎片化;

版本4:基于隨機(jī)數(shù)或偽隨機(jī)數(shù)生成,除了隨機(jī)性外沒(méi)有提供其他信息;

版本5:通過(guò) SHA-1 哈希算法生成,生成隨機(jī)分布的ID需要唯一的種子,這可能導(dǎo)致許多數(shù)據(jù)結(jié)構(gòu)碎片化;

這里面常用的就是 UUID4 了,但是,即使是隨機(jī)的,但是也是存在沖突的風(fēng)險(xiǎn)。

和 UUID 要么基于隨機(jī)數(shù),要么基于時(shí)間戳不同,ULID 是既基于時(shí)間戳又基于隨機(jī)數(shù),時(shí)間戳精確到毫秒,毫秒內(nèi)有1.21e + 24個(gè)隨機(jī)數(shù),不存在沖突的風(fēng)險(xiǎn),而且轉(zhuǎn)換成字符串比 UUID 更加友好。

ULID特性:

ulid()#01ARZ3NDEKTSV4RRFFQ69G5FAV

與UUID的128位兼容性

每毫秒1.21e + 24個(gè)唯一ULID

按字典順序(也就是字母順序)排序!

規(guī)范地編碼為26個(gè)字符串,而不是UUID的36個(gè)字符

使用Crockford的base32獲得更好的效率和可讀性(每個(gè)字符5位)

不區(qū)分大小寫

沒(méi)有特殊字符(URL安全)

單調(diào)排序順序(正確檢測(cè)并處理相同的毫秒)

ULID規(guī)范

以下是在python(ulid-py)中實(shí)現(xiàn)的ULID的當(dāng)前規(guī)范。二進(jìn)制格式已實(shí)現(xiàn)

01AN4Z07BY79KA1307SR9X4MV3

|----------||----------------|
TimestampRandomness
10chars16chars
48bits80bits

組成

時(shí)間戳

48位整數(shù)

UNIX時(shí)間(以毫秒為單位)

直到公元10889年,空間都不會(huì)耗盡。

隨機(jī)性

80位隨機(jī)數(shù)

如果可能的話,采用加密技術(shù)保證隨機(jī)性

排序

最左邊的字符必須排在最前面,最右邊的字符必須排在最后(詞匯順序)。必須使用默認(rèn)的ASCII字符集。在同一毫秒內(nèi),不能保證排序順序

編碼方式

如圖所示,使用了Crockford的Base32。該字母表不包括字母I,L,O和U,以避免混淆和濫用。

0123456789ABCDEFGHJKMNPQRSTVWXYZ

二進(jìn)制布局和字節(jié)順序

組件被編碼為16個(gè)八位位組。每個(gè)組件都以最高有效字節(jié)在前(網(wǎng)絡(luò)字節(jié)順序)進(jìn)行編碼。

0123
01234567890123456789012345678901
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|32_bit_uint_time_high|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|16_bit_uint_time_low|16_bit_uint_random|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|32_bit_uint_random|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|32_bit_uint_random|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+

應(yīng)用場(chǎng)景

替換數(shù)據(jù)庫(kù)自增id,無(wú)需DB參與主鍵生成

分布式環(huán)境下,替換UUID,全局唯一且毫秒精度有序

比如要按日期對(duì)數(shù)據(jù)庫(kù)進(jìn)行分區(qū)分表,可以使用ULID中嵌入的時(shí)間戳來(lái)選擇正確的分區(qū)分表

如果毫秒精度是可以接受的(毫秒內(nèi)無(wú)序),可以按照ULID排序,而不是單獨(dú)的created_at字段

用法(python)

安裝

pipinstallulid-py

創(chuàng)建一個(gè)全新的ULID。

時(shí)間戳記值(48位)來(lái)自 time.time(),精度為毫秒。

隨機(jī)值(80位)來(lái)自 os.urandom()。

>>>importulid
>>>ulid.new()

根據(jù)現(xiàn)有的128位值(例如UUID)創(chuàng)建新的ULID 。
支持ULID值類型有 int,bytes,str,和UUID。

>>>importulid,uuid
>>>value=uuid.uuid4()
>>>value
UUID('0983d0a2-ff15-4d83-8f37-7dd945b5aa39')
>>>ulid.from_uuid(value)

從現(xiàn)有時(shí)間戳值(例如datetime對(duì)象)創(chuàng)建新的ULID 。
支持時(shí)間戳值類型有int,float,str,bytes,bytearray,memoryview,datetime,Timestamp,和ULID

>>>importdatetime,ulid
>>>ulid.from_timestamp(datetime.datetime(1999,1,1))

根據(jù)現(xiàn)有的隨機(jī)數(shù)創(chuàng)建一個(gè)新的ULID。

支持隨機(jī)值類型有int,float,str,bytes,bytearray,memoryview,Randomness,和ULID。

>>>importos,ulid
>>>randomness=os.urandom(10)
>>>ulid.from_randomness(randomness)
>>>

一旦有了ULID對(duì)象,就有多種與之交互的方法。

timestamp()方法將為您提供ULID的前48位的時(shí)間戳快照,而randomness()方法將為您提供后80位的隨機(jī)數(shù)快照。

>>>importulid
>>>u=ulid.new()
>>>u

>>>u.timestamp()

>>>u.randomness()






審核編輯:劉清

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 二進(jìn)制
    +關(guān)注

    關(guān)注

    2

    文章

    807

    瀏覽量

    42339
  • URL
    URL
    +關(guān)注

    關(guān)注

    0

    文章

    141

    瀏覽量

    15869
  • 字符串
    +關(guān)注

    關(guān)注

    1

    文章

    590

    瀏覽量

    22306
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4827

    瀏覽量

    86804
  • UUID
    +關(guān)注

    關(guān)注

    0

    文章

    23

    瀏覽量

    8369

原文標(biāo)題:放棄使用UUID,ULID才是更好的選擇!

文章出處:【微信號(hào):DBDevs,微信公眾號(hào):數(shù)據(jù)分析與開發(fā)】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    mysql為什么推薦使用uuid呢?使用uuid究竟有什么壞處?

    分別是user_auto_key,user_uuid,user_random_key,分別表示自動(dòng)增長(zhǎng)的主鍵,uuid作為主鍵,隨機(jī)key作為主鍵,其它我們完全保持不變。
    的頭像 發(fā)表于 12-22 13:52 ?2715次閱讀
    mysql為什么<b class='flag-5'>不</b>推薦使用<b class='flag-5'>uuid</b>呢?使用<b class='flag-5'>uuid</b>究竟有什么壞處?

    想要用一個(gè)藍(lán)牙模塊與 DLP NIRscan Nano連接,怎么知道哪一個(gè)UUID才是該設(shè)備藍(lán)牙連接的UUID?

    DLP NIRscan Nano用戶指南里邊給了很多UUID,我現(xiàn)在想要用一個(gè)藍(lán)牙模塊與 DLP NIRscan Nano連接,但是沒(méi)弄明白哪一個(gè)UUID才是該設(shè)備藍(lán)牙連接的UUID
    發(fā)表于 03-03 07:19

    8.5.2數(shù)據(jù)選擇器的應(yīng)用(1)#硬聲創(chuàng)作季

    數(shù)據(jù)選擇
    學(xué)習(xí)硬聲知識(shí)
    發(fā)布于 :2022年12月03日 16:30:13

    8.5.2數(shù)據(jù)選擇器的應(yīng)用(2)#硬聲創(chuàng)作季

    數(shù)據(jù)選擇
    學(xué)習(xí)硬聲知識(shí)
    發(fā)布于 :2022年12月03日 16:31:02

    為什么選擇LDO 選擇BUCK?

    為什么選擇LDO 選擇BUCK?二者有什么區(qū)別?
    發(fā)表于 05-14 15:59

    客戶端UUID句柄多項(xiàng)選擇

    柏樹世界:我有下面兩個(gè)(2)個(gè)選擇題:1。客戶端UUID/句柄的選擇題:以下哪一個(gè)將被用來(lái)獲取連接客戶端的服務(wù)特性的UUID/句柄?A.
    發(fā)表于 09-19 08:17

    如何選擇uuid以確保它與標(biāo)準(zhǔn)服務(wù)的現(xiàn)有uuid沖突?

    在CyPress DOC中,我看到:“BLE SIG建議使用128位UUID,與基礎(chǔ)UUID不同,用于自定義屬性,以確保它不與標(biāo)準(zhǔn)服務(wù)的現(xiàn)有UUID沖突。”如何選擇StutuUID以確
    發(fā)表于 10-12 14:08

    請(qǐng)問(wèn)UUID申明可以聲明GATT_CHAR_USER_DESC_UUID嗎?

    UUID申明可以聲明GATT_CHAR_USER_DESC_UUID,和有通知功能的UUID可以聲明GATT_CLIENT_CHAR_C
    發(fā)表于 03-09 09:02

    如何獲取APP及其動(dòng)態(tài)庫(kù)的UUID

    LC_UUID 一般簡(jiǎn)稱為 UUID,是用來(lái)標(biāo)示 Mach-O 文件的,做過(guò)崩潰堆棧符號(hào)化還原的同學(xué)應(yīng)該都知道有 UUID 這個(gè)東西,你在進(jìn)行符號(hào)解析的時(shí)候,就需要找到與系統(tǒng)庫(kù)和你 APP
    發(fā)表于 09-25 09:25 ?1次下載

    隨著信息化時(shí)代的膨脹 智能會(huì)議平板才是會(huì)議的最佳選擇

    在過(guò)去的幾年里投影儀是一款唯一可以經(jīng)濟(jì)的呈現(xiàn)大尺寸屏幕的顯示設(shè)備,也因此成為大多企業(yè)的唯一選擇。如今隨著信息化時(shí)代的膨脹,大家對(duì)會(huì)議方式也有了巨大的變化,協(xié)作型會(huì)議正在逐漸取代傳統(tǒng)的會(huì)議模式。所以對(duì)于現(xiàn)在的企業(yè)來(lái)說(shuō),會(huì)議平板大屏才是會(huì)議的最佳
    發(fā)表于 11-03 08:58 ?1375次閱讀

    選擇移動(dòng)固態(tài)硬盤迷茫!教你如何選擇適合自己的國(guó)民好物

    選擇移動(dòng)固態(tài)硬盤迷茫!教你如何選擇適合自己的國(guó)民好物 很多人都知道,在內(nèi)容創(chuàng)作時(shí)代,儲(chǔ)存設(shè)備是用戶必不可少的工具,尤其是以便攜、輕量為主導(dǎo)的移動(dòng)存儲(chǔ)產(chǎn)品,已成為內(nèi)容創(chuàng)作者不可或缺的生產(chǎn)力工具。面對(duì)
    的頭像 發(fā)表于 08-11 15:22 ?1857次閱讀
    <b class='flag-5'>選擇</b>移動(dòng)固態(tài)硬盤<b class='flag-5'>不</b>迷茫!教你如何<b class='flag-5'>選擇</b>適合自己的國(guó)民好物

    為什么選擇UUIDUUID有哪些特性

    這里面常用的就是 UUID4 了,但是,即使是隨機(jī)的,但是也是存在沖突的風(fēng)險(xiǎn)。和 UUID 要么基于隨機(jī)數(shù),要么基于時(shí)間戳不同,ULID 是既基于時(shí)間戳又基于隨機(jī)數(shù),時(shí)間戳精確到毫秒,毫秒內(nèi)有1.21e + 24個(gè)隨機(jī)數(shù),不存在
    的頭像 發(fā)表于 10-13 10:29 ?1486次閱讀

    在mysql中設(shè)計(jì)表為什么建議采用uuid呢?

    user_auto_key,user_uuid,user_random_key,分別表示自動(dòng)增長(zhǎng)的主鍵,uuid 作為主鍵,隨機(jī) key 作為主鍵,其它我們完全保持不變。
    的頭像 發(fā)表于 12-02 09:49 ?1010次閱讀

    燈板制作的新選擇,這些基板比鋁基板更好

    燈板制作的新選擇,這些基板比鋁基板更好
    的頭像 發(fā)表于 11-06 10:06 ?1111次閱讀

    rtthread和freertos哪個(gè)更好 選擇哪個(gè)

    rtthread和freertos哪個(gè)更好 選擇哪個(gè)? RT-Thread和FreeRTOS都是流行的開源實(shí)時(shí)操作系統(tǒng)(RTOS),在選擇哪個(gè)更好之前,我們需要詳細(xì)了解它們的特點(diǎn)、特點(diǎn)
    的頭像 發(fā)表于 12-08 10:18 ?1w次閱讀
    主站蜘蛛池模板: 怡红院日本一道日本久久 | 国产亚洲精品仙踪林在线播放 | japanese色系国产在线高清 | 日本经典在线三级视频 | 亚洲天天做日日做天天看2018 | 新版天堂资源在线官网8 | 欧美精品1 | 亚洲综合在线观看一区www | 亚洲一区中文字幕在线观看 | 天堂社区在线观看 | 一级a爰片久久毛片 | 老司机亚洲精品影院在线 | 国模私拍一区二区 | 午夜色大片在线观看 | 在线jlzzjlzz免费播放 | 日处女穴 | 老师我好爽再深一点好大 | 亚洲免费黄色网址 | 九九热精品视频 | 精品一区二区三区免费毛片爱 | 侵犯希崎中文字幕在线 | 久久婷婷一区二区三区 | 浓厚な接吻と肉体の交在线观看 | 女同久久| 亚洲一区二区免费在线观看 | 免费久久精品国产片香蕉 | 亚欧免费视频一区二区三区 | 色人人| 国产三级自拍视频 | 天天爽夜爽免费精品视频 | 午夜爽爽性刺激一区二区视频 | 天天爽夜夜爽免费看 | 202z国产高清日本在线播放 | 免费又黄又硬又大爽日本 | 欧美性一级交视频 | 四虎永久网址在线观看 | 欧美爱爱网 | 欧美一级色视频 | 亚洲视频在线一区二区 | 夜性影院| 欧美一级视频在线观看 |