生成分布式序列ID

生成分布式序列ID

介紹

在很多分布式系統(tǒng)中睦授,需要生成唯一的id。如在分庫(kù)分表的情況下摔寨,給某個(gè)邏輯表生成唯一id睹逃。既要保證id的唯一性,也需要保證生成id的性能祷肯,而且需要持久化沉填,防止在id生成器重啟之后,造成id不唯一佑笋。

實(shí)現(xiàn)

https://gitee.com/majinliang123/messtin-sequence

思路

使用數(shù)據(jù)庫(kù)記錄下一個(gè)id

當(dāng)想獲取id時(shí)翼闹,需要查詢(xún)數(shù)據(jù)庫(kù),數(shù)據(jù)庫(kù)中的值就是你想要的下一個(gè)值蒋纬。但是在這個(gè)過(guò)程中猎荠,可能有多個(gè)id生成器同時(shí)想要生成下一個(gè)id,所以都在更新數(shù)據(jù)庫(kù)蜀备。在我們更新數(shù)據(jù)庫(kù)時(shí)关摇,需要將id更新為id + 1,然后查詢(xún)這個(gè)id值碾阁,id - 1就是我們想要的输虱。這兩步操作必須在同一個(gè)事務(wù)中,使用數(shù)據(jù)庫(kù)的事務(wù)保證id更新過(guò)程中不會(huì)發(fā)生錯(cuò)亂(當(dāng)我們更新id時(shí)脂凶,數(shù)據(jù)庫(kù)會(huì)阻塞其他的更新操作宪睹,直到我們事務(wù)提交,其他的更新操作才能更新id的值蚕钦,這就保證了數(shù)據(jù)庫(kù)中id的正確性)亭病。不應(yīng)該先讀再更新,因?yàn)樵谧x的過(guò)程中嘶居,可能已經(jīng)有其他id生成器更新了這個(gè)值罪帖,導(dǎo)致我們讀的值是過(guò)時(shí)的。

每次獲取多個(gè)id,以防多次更新數(shù)據(jù)庫(kù)

在我們更新數(shù)據(jù)id時(shí)整袁,僅僅id + 1是不夠的菠齿,這會(huì)造成我們頻繁的更新數(shù)據(jù)庫(kù),性能比較低葬项。一般我們每次更新都是id + 500泞当,這樣在當(dāng)前id生成器中就有500個(gè)id可以分配(id ~ id + 500 -1)迹蛤,當(dāng)分配完再去數(shù)據(jù)庫(kù)中取下一批id民珍,必須保證id生成器的線程安全。在id生成器中保存著當(dāng)前id生成器的當(dāng)前id和最大id盗飒,當(dāng)當(dāng)前id達(dá)到最大id嚷量,就取數(shù)據(jù)庫(kù)中獲取下一批。

原文連接 https://github.com/majinliang123/Article/blob/master/%E7%94%9F%E6%88%90%E5%88%86%E5%B8%83%E5%BC%8F%E5%BA%8F%E5%88%97ID.MD

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末逆趣,一起剝皮案震驚了整個(gè)濱河市蝶溶,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌宣渗,老刑警劉巖抖所,帶你破解...
    沈念sama閱讀 210,978評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異痕囱,居然都是意外死亡田轧,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門(mén)鞍恢,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)傻粘,“玉大人,你說(shuō)我怎么就攤上這事帮掉∠蚁ぃ” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,623評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵蟆炊,是天一觀的道長(zhǎng)稽莉。 經(jīng)常有香客問(wèn)我,道長(zhǎng)涩搓,這世上最難降的妖魔是什么肩祥? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,324評(píng)論 1 282
  • 正文 為了忘掉前任,我火速辦了婚禮缩膝,結(jié)果婚禮上混狠,老公的妹妹穿的比我還像新娘。我一直安慰自己疾层,他們只是感情好将饺,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,390評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般予弧。 火紅的嫁衣襯著肌膚如雪刮吧。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,741評(píng)論 1 289
  • 那天掖蛤,我揣著相機(jī)與錄音杀捻,去河邊找鬼。 笑死蚓庭,一個(gè)胖子當(dāng)著我的面吹牛致讥,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播器赞,決...
    沈念sama閱讀 38,892評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼垢袱,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了港柜?” 一聲冷哼從身側(cè)響起请契,我...
    開(kāi)封第一講書(shū)人閱讀 37,655評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎夏醉,沒(méi)想到半個(gè)月后爽锥,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,104評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡畔柔,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年氯夷,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片释树。...
    茶點(diǎn)故事閱讀 38,569評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡肠槽,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出奢啥,到底是詐尸還是另有隱情秸仙,我是刑警寧澤,帶...
    沈念sama閱讀 34,254評(píng)論 4 328
  • 正文 年R本政府宣布桩盲,位于F島的核電站寂纪,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏赌结。R本人自食惡果不足惜捞蛋,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,834評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望柬姚。 院中可真熱鬧拟杉,春花似錦、人聲如沸量承。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,725評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至拿穴,卻和暖如春泣洞,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背默色。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,950評(píng)論 1 264
  • 我被黑心中介騙來(lái)泰國(guó)打工球凰, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人腿宰。 一個(gè)月前我還...
    沈念sama閱讀 46,260評(píng)論 2 360
  • 正文 我出身青樓呕诉,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親酗失。 傳聞我的和親對(duì)象是個(gè)殘疾皇子义钉,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,446評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • ORA-00001: 違反唯一約束條件 (.) 錯(cuò)誤說(shuō)明:當(dāng)在唯一索引所對(duì)應(yīng)的列上鍵入重復(fù)值時(shí)昧绣,會(huì)觸發(fā)此異常规肴。 O...
    我想起個(gè)好名字閱讀 5,249評(píng)論 0 9
  • 數(shù)據(jù)庫(kù)范式 https://www.zhihu.com/question/24696366 索引 索引可以加快數(shù)據(jù)...
    EakonZhao閱讀 3,191評(píng)論 3 23
  • 轉(zhuǎn)載:細(xì)聊分布式ID生成方法 一、需求緣起 幾乎所有的業(yè)務(wù)系統(tǒng)夜畴,都有生成一個(gè)記錄標(biāo)識(shí)的需求拖刃,例如: (1)消息標(biāo)識(shí)...
    meng_philip123閱讀 2,559評(píng)論 0 17
  • --- layout: post title: "如果有人問(wèn)你關(guān)系型數(shù)據(jù)庫(kù)的原理,叫他看這篇文章(轉(zhuǎn))" date...
    藍(lán)墜星閱讀 780評(píng)論 0 3
  • 最近碰到幾個(gè)業(yè)務(wù)場(chǎng)景贪绘,會(huì)遇到并發(fā)的問(wèn)題兑牡。在單實(shí)例情況下,我們會(huì)通過(guò)java.util.concurrent包...
    菜鳥(niǎo)小玄閱讀 2,251評(píng)論 0 5