成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

分布式內(nèi)存緩存系統(tǒng)設計

gitmilk / 947人閱讀

摘要:客戶端緩存代理緩存實例內(nèi)存總量限制緩存安全機制實例都會開啟功能實例都監(jiān)聽在內(nèi)網(wǎng)核心流程新增節(jié)點刪除節(jié)點緩存緩存參考資源一致性原理一致性實現(xiàn)通訊協(xié)議規(guī)范

1.問題

任何平臺隨著用戶規(guī)模的擴大、功能不斷的添加,持久化數(shù)據(jù)庫層承受的讀寫壓力會越來越大,一旦數(shù)據(jù)庫承壓過大會導致讀寫性能陡然下降,嚴重時會導致大量的業(yè)務請求超時,進而發(fā)生“雪崩”引發(fā)嚴重的故障。

2.解決方案

在業(yè)務層和數(shù)據(jù)庫持久層之間引入一層內(nèi)存緩存層,對于復雜且業(yè)務邏輯上不會變化的查詢結果進行緩存,業(yè)務請求再次發(fā)起時,每次都先從緩存層中查詢,從而大大減少對數(shù)據(jù)庫的查詢,減小對數(shù)據(jù)庫的壓力。

3.分布式內(nèi)存緩存、本地單點緩存、應用層緩存對比
類型 穩(wěn)定性 擴展性 通用性 對代碼的侵入性
應用層緩存 應用會頻繁重啟更新,緩存易丟失,穩(wěn)定性不佳 差,受限于進程的資源限制 差,不同應用難以復用 代碼侵入性小,無網(wǎng)絡操作,只需要操作應用進程內(nèi)存
本地單點緩存 獨立的緩存應用(redis、memcached等),不會頻繁重啟,穩(wěn)定性一般,但有單點故障問題 一般,受限于單服務器資源限制 一般,業(yè)務應用和緩存應用有強耦合 代碼侵入性一般,需要引入對應的api通常有網(wǎng)絡操作
分布式內(nèi)存緩存 分布式系統(tǒng),具備故障恢復功能,無單點故障問題,穩(wěn)健性佳 好,支持水平擴展 好,對業(yè)務層提供通用接口,后端具體的緩存應用對業(yè)務透明 代碼侵入性一般,需要引入通用的api通常有網(wǎng)絡操作
4.分布式內(nèi)存緩存系統(tǒng)設計 4.1總體架構圖

4.2自定義的客戶端協(xié)議

業(yè)務模塊采用自定義應用層協(xié)議和cacheProxy交互

整個cache后端采用什么協(xié)議,什么存儲(redis,memcached等)對業(yè)務模塊透明

cache后端和業(yè)務端進行了隔離,修改互不影響

4.3負載均衡與容錯機制

采用一致性hash算法,即使部分節(jié)點down機,也不會導致全部的緩存失效,新增節(jié)點也不會導致大量緩存失效和重建

一份緩存數(shù)據(jù)保留兩份,當前hash節(jié)點和下一個真實的hash節(jié)點(超時時間只有設置的超時時間的一半),單個節(jié)點down機時,緩存也不會馬上失效

cacheMan是一個弱的管理節(jié)點,負責監(jiān)控,刪除節(jié)點,新增節(jié)點,可以任意啟停

4.4緩存維護與淘汰機制

redis原生超時機制+三層LRU緩存架構,減少最終穿透到redis實例上的請求。

客戶端LRU緩存

cacheProxy代理LRU緩存

redis實例內(nèi)存總量限制+LRU緩存

4.5安全機制

redis實例都會開啟auth功能

redis實例都監(jiān)聽在內(nèi)網(wǎng)ip

4.6核心流程

新增redis節(jié)點

刪除redis節(jié)點

set緩存

get緩存

5.參考資源

一致性hash原理:http://blog.codinglabs.org/ar...

一致性hash實現(xiàn):https://github.com/pzx6019171...

redis通訊協(xié)議規(guī)范:http://www.redis.cn/topics/pr...

文章版權歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/61695.html

相關文章

  • 布式內(nèi)存緩存系統(tǒng)設計

    摘要:客戶端緩存代理緩存實例內(nèi)存總量限制緩存安全機制實例都會開啟功能實例都監(jiān)聽在內(nèi)網(wǎng)核心流程新增節(jié)點刪除節(jié)點緩存緩存參考資源一致性原理一致性實現(xiàn)通訊協(xié)議規(guī)范 1.問題 任何平臺隨著用戶規(guī)模的擴大、功能不斷的添加,持久化數(shù)據(jù)庫層承受的讀寫壓力會越來越大,一旦數(shù)據(jù)庫承壓過大會導致讀寫性能陡然下降,嚴重時會導致大量的業(yè)務請求超時,進而發(fā)生雪崩引發(fā)嚴重的故障。 2.解決方案 在業(yè)務層和數(shù)據(jù)庫持久層之...

    red_bricks 評論0 收藏0
  • [讀書筆記]大型布式網(wǎng)站架構設計與實踐.布式緩存

    摘要:接下來將介紹分布式緩存的典型代表,以及分布式緩存的應用場景。的分布式實現(xiàn)本身并不是一種分布式的緩存系統(tǒng),它的分布式是由訪問它的客戶端來實現(xiàn)的。 前言:本書是對分布式系統(tǒng)架構涉及到的相關技術的一本科普書籍。由于很難作為開發(fā)參考,只能但求了解。所以通篇淺讀,對分布式系統(tǒng)進行大致的了解。因為寫的非常好,感覺非常有意思,自己也做不出總結。所謂的讀書筆記也就演變成了摘抄。 簡介 一個大型、穩(wěn)健、...

    pepperwang 評論0 收藏0
  • 馬蜂窩推薦系統(tǒng)容災緩存服務的設計與實現(xiàn)

    摘要:馬蜂窩推薦系統(tǒng)對于請求的平均處理時延要求在級別,時延的線保持在以內(nèi)。任務隊列與異步寫入這里我們使用了中的線程池來實現(xiàn)。三優(yōu)化方向基于和,我們在現(xiàn)有的推薦系統(tǒng)中增加了一個本地容災緩存系統(tǒng),當依賴服務或者應用本身突發(fā)異常時可以返回緩存的數(shù)據(jù)。 數(shù)據(jù)庫突然斷開連接、第三方接口遲遲不返回結果、高峰期網(wǎng)絡發(fā)生抖動...... 當程序突發(fā)異常時,我們的應用可以告訴調(diào)用方或者用戶「對不起,服務器出了...

    Dean 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<