• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            牽著老婆滿街逛

            嚴(yán)以律己,寬以待人. 三思而后行.
            GMail/GTalk: yanglinbo#google.com;
            MSN/Email: tx7do#yahoo.com.cn;
            QQ: 3 0 3 3 9 6 9 2 0 .

            Twitter Snowflake

            轉(zhuǎn)載自:http://blog.yxwang.me/2012/08/twitter-snowflake/

            這是一篇兩年前 Twitter 開發(fā)團隊寫的文章,今天挖出來研究了一下。原文地址 http://engineering.twitter.com/2010/06/announcing-snowflake.html

            Twitter 早期用 MySQL 存儲數(shù)據(jù),隨著用戶的增長,單一的 MySQL 實例沒法承受海量的數(shù)據(jù),開發(fā)團隊就開始用 Cassandra 和 sharded MySQL 替代原有的系統(tǒng)。然而和 MySQL 不同的是,Cassandra 沒有內(nèi)置為每一條數(shù)據(jù)生成唯一 ID 的功能,因為在一個分布式環(huán)境下,很難有完美的 ID 生成方案。

            對于 Twitter 而言,這樣的 ID 生成方案要滿足兩個基本的要求,一是每秒能生成幾十萬條 ID 用于標(biāo)識不同的 tweet;二是這些 ID 應(yīng)該可以有個大致的順序,也就是說發(fā)布時間相近的兩條 tweet,它們的 ID 也應(yīng)當(dāng)相近,這樣才能方便各種客戶端對 tweet 進行排序。

            第一個要求意味著 ID 生成要以一種非協(xié)作的(uncoordinated)的方式進行,例如不能有一個全局的原子變量。

            第二個要求使得 tweet 按 ID 排序后滿足 k-sorted 條件。如果序列 A 要滿足 k-sorted,當(dāng)且僅當(dāng)對于任意的 p, q,如果 1 <= p <= q - k (1 <= p <= q <= n),則有 A[p] <= A[q]。換句話說,如果元素 p 排在 q 前面,且相差至少 k 個位置,那么 p 必然小于或等于 q。如果 tweet 序列滿足這個條件,要獲取第 r 條 tweet 之后的消息,只要從第 r - k 條開始查找即可。

            Twitter 解決這兩個問題的方案非常簡單高效:每一個 ID 都是 64 位數(shù)字,由時間戳、節(jié)點號和序列編號組成。其中序列編號是每個節(jié)點本地生成的序號,而節(jié)點號則由 ZooKeeper 維護。

            具體的參數(shù)可以在這個 IdWorker.scala 中看到。序列編號有 12 位,意味著每個節(jié)點在每毫秒可以產(chǎn)生 4096 個 ID。節(jié)點號在源碼中被分成兩部分,數(shù)據(jù)中心的 ID 和節(jié)點 ID,各自占 5 位。時間戳則是記錄了從 1288834974657 (Thu, 04 Nov 2010 01:42:54 GMT) 這一時刻到當(dāng)前時間所經(jīng)過的毫秒數(shù),占 41 位(還有一位是符號位,永遠為 0)。

            posted on 2014-05-29 02:03 楊粼波 閱讀(669) 評論(0)  編輯 收藏 引用 所屬分類: C++

            国产高潮国产高潮久久久| 久久91精品综合国产首页| 久久国产精品国语对白| 成人妇女免费播放久久久| 99久久无色码中文字幕人妻| 久久久久综合国产欧美一区二区| 久久国产精品-国产精品| 93精91精品国产综合久久香蕉| 精品九九久久国内精品| 99久久99久久精品国产| 久久成人18免费网站| 午夜精品久久久内射近拍高清 | 国产一区二区三精品久久久无广告| 69久久精品无码一区二区| 久久久久亚洲av无码专区喷水| 久久久久人妻精品一区| 久久久久四虎国产精品| 精品国产青草久久久久福利| 色偷偷91久久综合噜噜噜噜| 久久精品国产清自在天天线| 一本一本久久A久久综合精品| 精品少妇人妻av无码久久| 久久亚洲国产欧洲精品一| 久久精品视频91| 久久强奷乱码老熟女网站| 97久久香蕉国产线看观看| 久久久久久无码国产精品中文字幕 | 久久夜色精品国产亚洲| 久久久国产精品亚洲一区| 久久久青草青青亚洲国产免观| 精品久久久久久国产三级| 最新久久免费视频| 狠狠色丁香久久综合婷婷| 亚洲国产婷婷香蕉久久久久久| 人妻无码αv中文字幕久久| 成人国内精品久久久久影院VR| 欧洲性大片xxxxx久久久| 97久久久精品综合88久久| 久久综合五月丁香久久激情| 亚洲精品无码久久久久| 久久综合精品国产一区二区三区 |