很多人看到 J2Cache 第一眼時,會認爲這就是一個普普統統的緩存框架,和例如 Ehcache、Caffeine 、Spring Cache 之類的項目沒什麼區別,無非是造了一個新的輪子而已。事實上徹底不是一回事!數據庫
目前緩存的解決方案通常有兩種:緩存
內存緩存(如 Ehcache) —— 速度快,進程內可用
集中式緩存(如 Redis)—— 可同時爲多節點提供服務
現有的緩存框架已經很是成熟並且優秀,J2Cache 無意造一個新的輪子,它要解決的幾個問題以下:性能優化
使用內存緩存時,一旦應用重啓後,因爲緩存數據丟失,緩存雪崩,給數據庫形成巨大壓力,致使應用堵塞
使用內存緩存時,多個應用節點沒法共享緩存數據
使用集中式緩存,因爲大量的數據經過緩存獲取,致使緩存服務的數據吞吐量太大,帶寬跑滿。現象就是 Redis 服務負載不高,可是因爲機器網卡帶寬跑滿,致使數據讀取很是慢
在遭遇問題一、2 時,不少人天然而然會想到使用 Redis 來緩存數據,所以就難以免的致使了問題3的發生。服務器
當發生問題 3 時,又有不少人想到 Redis 的集羣,經過集羣來下降緩存服務的壓力,特別是帶寬壓力。架構
但其實,這個時候的 Redis 上的數據量並不必定大,僅僅是數據的吞吐量大而已。併發
我們假設這樣一個場景:框架
有這麼一個網站,某個頁面天天的訪問量是 1000萬,每一個頁面從緩存讀取的數據是 50K。緩存數據存放在一個 Redis 服務,機器使用千兆網卡。那麼這個 Redis 一天要承受 500G 的數據流,至關於平均每秒鐘是 5.78M 的數據。而網站通常都會有高峯期和低峯期,兩個時間流量的差別多是百倍以上。咱們假設高峯期每秒要承受的流量比平均值高 50 倍,也就是說高峯期 Redis 服務每秒要傳輸超過 250 兆的數據。請注意這個 250 兆的單位是 byte,而千兆網卡的單位是「bit」 ,你懂了嗎? 這已經遠遠超過 Redis 服務的網卡帶寬。運維
因此若是你能發現這樣的問題,通常你會這麼作:分佈式
升級到萬兆網卡 —— 這個有多麻煩,相信不少人知道,特別是一些雲主機根本沒有萬兆網卡給你使用(運維工程師通常會給這樣的建議)
多個 Redis 搭建集羣,將流量分攤多多臺機器上
若是你採用第2種方法來解決上述的場景中碰到的問題,那麼你最好準備 5 個 Redis 服務來支撐。在緩存服務這塊成本直接攀升了 5 倍。你有錢固然沒任何問題,可是結構就變得很是複雜了,並且可能你緩存的數據量其實不大,1000 萬高頻次的緩存讀寫 Redis 也能輕鬆應付,但是由於帶寬的問題,你不得不付出 5 倍的成本。微服務
那麼 J2Cache 的用武之處就在這裏。
若是咱們不用每次頁面訪問的時候都去 Redis 讀取數據,那麼 Redis 上的數據流量至少下降 1000 倍甚至更多,以致於一臺 Redis 能夠輕鬆應付。
J2Cache 其實不是一個緩存框架,它是一個緩存框架的橋樑。它利用現有優秀的內存緩存框架做爲一級緩存,而把 Redis 做爲二級緩存。全部數據的讀取先從一級緩存中讀取,不存在時再從二級緩存讀取,這樣來確保對二級緩存 Redis 的訪問次數降到最低。
有人會質疑說,那豈不是應用節點的內存佔用要飆升?個人答案是 —— 如今服務器的內存都是幾十 G 打底,多則百 G 數百 G,這點點的內存消耗徹底不在話下。其次一級緩存框架能夠經過配置來控制在內存中存儲的數據量,因此不用擔憂內存溢出的問題。
剩下的另一個問題就是,當緩存數據更新的時候,怎麼確保每一個節點內存中的數據是一致的。而這一點算你問到點子上了,這偏偏是 J2Cache 的核心所在。
J2Cache 目前提供兩種節點間數據同步的方案 —— Redis Pub/Sub 和 JGroups 。當某個節點的緩存數據須要更新時,J2Cache 會經過 Redis 的消息訂閱機制或者是 JGroups 的組播來通知集羣內其餘節點。當其餘節點收到緩存數據更新的通知時,它會清掉本身內存裏的數據,而後從新從 Redis 中讀取最新數據。
ache 緩存數據讀寫的閉環。
爲何不用 Ehcache 的集羣方案?
對 Ehcache 比較熟悉的人還會問的就是這個問題,Ehcache 自己是提供集羣模式的,能夠在多個節點同步緩存數據。可是 Ehcache 的作法是將整個緩存數據在節點間進行傳輸。如我們前面的說的,一個頁面須要讀取 50K 的緩存數據,當這 50K 的緩存數據有更新時,那麼須要在幾個節點間傳遞整個 50K 的數據。這也會形成應用節點間大量的數據傳輸,這個狀況徹底不可控。
補充:固然這個單個數據傳輸量自己並不比使用 J2Cache 多,可是 ehcache 利用 jgroups 來同步數據的作法,在實際測試過程當中發現可靠性仍是略低,並且 jgroups 的同步數據在雲主機上沒法使用。
而 J2Cache 傳輸的僅僅是緩存的 key 而已,所以相比 Ehcache 的集羣模式,J2Cache 要傳輸的數據極其小,對節點間的數據通訊徹底不會產生大的影響。
那如何學習才能快速入門並精通呢?
當真正開始學習的時候不免不知道從哪入手,致使效率低下影響繼續學習的信心。
但最重要的是不知道哪些技術須要重點掌握,學習時頻繁踩坑,最終浪費大量時間,因此有一套實用的視頻課程用來跟着學習是很是有必要的。
爲了讓學習變得輕鬆、高效,今天給你們免費分享一套阿里架構師傳授的一套教學資源。加羣:874811168免費獲取如下資料 幫助你們在成爲架構師的道路上披荊斬棘。
這套視頻課程詳細講解了(Spring,MyBatis,Netty源碼分析,高併發、高性能、分佈式、微服務架構的原理,JVM性能優化、分佈式架構)等成爲架構師必備的內容!