京東的本地?zé)狳c(diǎn)緩存分析

什么是本地?zé)狳c(diǎn)緩存缸濒?

在高并發(fā)場景中捉邢,為了提高讀取速度康震,降低對DB層(mysql或者redis)壓力蛛芥,往往需要進(jìn)行JVM本地緩存提鸟。但是對于數(shù)據(jù)量非常大的情況下時(例如上百萬的商品),業(yè)務(wù)側(cè)無挑剔的全部進(jìn)行緩存(結(jié)合失效策略)仅淑,可能導(dǎo)致緩存過多的數(shù)據(jù)称勋,造成內(nèi)存的浪費(fèi)。而如果設(shè)置緩存數(shù)量大小進(jìn)行限制漓糙,緩存的頻繁失效導(dǎo)致效果不佳铣缠。而京東的hotkey就是為了解決這個問題。

看下架構(gòu)

1.png
  • 比較簡單昆禽,就不對架構(gòu)圖進(jìn)行解釋了蝗蛙。直接看看核心點(diǎn)。

要點(diǎn)

  • 客戶端如何收集key的醉鳖?
    應(yīng)用側(cè)通過集成sdk捡硅,使用sdk的JdHotKeyStore.getValue。
    image.png
  • 服務(wù)端是如何計算熱點(diǎn)key的盗棵?
    首先server通過netty接收消息壮韭,使用NodesServerHandler來處理消息北发。該處理器主要是通過 一組INettyMsgFilter過濾器完成。
    AppNameFilter喷屋,用于保存客戶端應(yīng)用對應(yīng)的通信channel
    HeartBeatFilter琳拨,用于響應(yīng)心跳
    HotKeyFilter,用于進(jìn)行熱點(diǎn)key探測屯曹。這里重點(diǎn)介紹下該Filter狱庇。
  • HotKeyFilter 如何工作?
    過濾器通過生產(chǎn)者消費(fèi)者模式恶耽,通過生產(chǎn)者將消息發(fā)送阻塞隊里密任。然后多線程消費(fèi)者進(jìn)行消費(fèi)。


    image.png
  • 在消費(fèi)的時候就是在進(jìn)行統(tǒng)計偷俭,那么是如何統(tǒng)計key的訪問次數(shù)的呢浪讳?
    采用的是滑動窗口實(shí)現(xiàn),這也是流控的常用算法涌萤。這里簡單做下說明:
    首先server中將每個key創(chuàng)建滑動窗口對象淹遵,整體數(shù)據(jù)結(jié)構(gòu)如下:
    Map<appName, Cache<key, SlidingWindow>>
class SlidingWindow {
/**
     * 循環(huán)隊列,就是裝多個窗口用形葬,該數(shù)量是windowSize的2倍
     */
    private AtomicInteger[] timeSlices;
    /**
     * 隊列的總長度
     */
    private int timeSliceSize;
    /**
     * 每個時間片的時長合呐,以毫秒為單位
     */
    private int timeMillisPerSlice;
    /**
     * 共有多少個時間片(即窗口長度)
     */
    private int windowSize;
    /**
     * 在一個完整窗口期內(nèi)允許通過的最大閾值
     */
    private int threshold;
    /**
     * 該滑窗的起始創(chuàng)建時間,也就是第一個數(shù)據(jù)
     */
    private long beginTimestamp;
    /**
     * 最后一個數(shù)據(jù)的時間戳
     */
    private long lastAddTimestamp;
}
  • 滑動算法是如何工作的笙以?
    通過簡單舉例來說明淌实, 現(xiàn)在假設(shè)我們需要在檢測出一個key在5s內(nèi)訪問是否超過100。將windowSize設(shè)置為5猖腕, 每個時間片是1000ms拆祈,一共設(shè)置10個時間片(為啥?)
    如下圖倘感,計算當(dāng)前時間的時間片放坏。
    image.png

    對當(dāng)前時間片進(jìn)行+1操作,假設(shè)當(dāng)前時間片為7老玛,那么有效的時間片為 7 6 5 4 3淤年,其他時間片需要進(jìn)行清零。通過計算7 6 5 4 3時間片得到總數(shù)蜡豹。
  • 上個問題中麸粮,時間片設(shè)置為windowSize的2倍是否合理?
    我們考慮每個時間點(diǎn)只會使用一個時間片镜廉,其實(shí)只要設(shè)置為windowSize+1即可弄诲, 這樣每次只需要清理一個時間片。
    后來和小伙伴們討論了下發(fā)現(xiàn)還是得用2倍窗口娇唯,原因就不說了齐遵,給大家點(diǎn)思考空間
  • 最后回顧下整體流程
  1. NodesServerHandler使用AppNameFilter保存應(yīng)用對應(yīng)的channel信息
  2. 使用HotKeyFilter將消息發(fā)送隊列寂玲,使用消費(fèi)者進(jìn)行計算
  3. 計算時使用滑動窗口計算,對應(yīng)超過閾值的key梗摇,使用已經(jīng)保存的channel進(jìn)行消息的發(fā)送
  4. 客戶端收到消息便在本地進(jìn)行緩存拓哟。
  • 簡單分析,如有不足留美,請指正彰檬,謝謝

參考

京東hotkey

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末伸刃,一起剝皮案震驚了整個濱河市谎砾,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌捧颅,老刑警劉巖景图,帶你破解...
    沈念sama閱讀 221,820評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異碉哑,居然都是意外死亡挚币,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,648評論 3 399
  • 文/潘曉璐 我一進(jìn)店門扣典,熙熙樓的掌柜王于貴愁眉苦臉地迎上來妆毕,“玉大人,你說我怎么就攤上這事贮尖〉颜常” “怎么了?”我有些...
    開封第一講書人閱讀 168,324評論 0 360
  • 文/不壞的土叔 我叫張陵湿硝,是天一觀的道長薪前。 經(jīng)常有香客問我,道長关斜,這世上最難降的妖魔是什么示括? 我笑而不...
    開封第一講書人閱讀 59,714評論 1 297
  • 正文 為了忘掉前任,我火速辦了婚禮痢畜,結(jié)果婚禮上垛膝,老公的妹妹穿的比我還像新娘。我一直安慰自己丁稀,他們只是感情好吼拥,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,724評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著二驰,像睡著了一般扔罪。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上桶雀,一...
    開封第一講書人閱讀 52,328評論 1 310
  • 那天矿酵,我揣著相機(jī)與錄音唬复,去河邊找鬼。 笑死全肮,一個胖子當(dāng)著我的面吹牛敞咧,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播辜腺,決...
    沈念sama閱讀 40,897評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼休建,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了评疗?” 一聲冷哼從身側(cè)響起测砂,我...
    開封第一講書人閱讀 39,804評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎百匆,沒想到半個月后砌些,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,345評論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡加匈,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,431評論 3 340
  • 正文 我和宋清朗相戀三年存璃,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片雕拼。...
    茶點(diǎn)故事閱讀 40,561評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡纵东,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出啥寇,到底是詐尸還是另有隱情偎球,我是刑警寧澤,帶...
    沈念sama閱讀 36,238評論 5 350
  • 正文 年R本政府宣布示姿,位于F島的核電站甜橱,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏栈戳。R本人自食惡果不足惜岂傲,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,928評論 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望子檀。 院中可真熱鬧镊掖,春花似錦、人聲如沸褂痰。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,417評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽缩歪。三九已至归薛,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背主籍。 一陣腳步聲響...
    開封第一講書人閱讀 33,528評論 1 272
  • 我被黑心中介騙來泰國打工习贫, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人千元。 一個月前我還...
    沈念sama閱讀 48,983評論 3 376
  • 正文 我出身青樓苫昌,卻偏偏與公主長得像,于是被迫代替她去往敵國和親幸海。 傳聞我的和親對象是個殘疾皇子祟身,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,573評論 2 359

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