從零開始學 Java - Spring 集成 Memcached 緩存配置(一)

来源:http://www.cnblogs.com/mafly/archive/2016/09/26/think_memcached.html
-Advertisement-
Play Games

硬碟和記憶體的作用是什麼 硬碟的作用毫無疑問我們大家都清楚,不就是用來存儲數據文件的麽?如照片、視頻、各種文檔或等等,肯定也有你喜歡的某位島國老師的動作片,這個時候無論我們電腦是否關機重啟它們永遠在那裡,不會無辜地消失掉。那記憶體是用來做什麼的呢?我是不能準確的描述出來,所以我抄襲了下麵描述記憶體作用的一 ...


硬碟和記憶體的作用是什麼

硬碟的作用毫無疑問我們大家都清楚,不就是用來存儲數據文件的麽?如照片、視頻、各種文檔或等等,肯定也有你喜歡的某位島國老師的動作片,這個時候無論我們電腦是否關機重啟它們永遠在那裡,不會無辜地消失掉。那記憶體是用來做什麼的呢?我是不能準確的描述出來,所以我抄襲了下麵描述記憶體作用的一段話:

記憶體就是暫時存儲程式以及數據的地方,比如當我們在使用 WPS 處理文稿時,當你在鍵盤上敲入字元時,它就被存入記憶體中,當你選擇存檔時,記憶體中的數據才會被存入硬(磁)盤。

為什麼這麼做?
由於硬碟 IO(讀寫)速度比較慢,CPU 如果運行程式的時候,所有數據都直接從硬碟中讀寫,會非常影響效率。所以, CPU 會將運行軟體時要用的數據一次性從硬碟調用到運行速度很快的記憶體,然後, CPU 再與記憶體進行數據交換。記憶體是易失性存儲器,只要你斷了電,記憶體中的數據就沒有了。

我們程式界有沒有「記憶體」呢

當然有。一個簡單的 Web 軟體系統必須包含前端頁面、後端程式、資料庫、伺服器等等這些最基礎的東西,如果我們稍微對系統要求高一點的話,我們發現每次從資料庫讀取數據的時間都有些漫長,這時候的資料庫可以理解為電腦中的硬碟,那我們能不能提高直接從資料庫取數據的性能?或者說減少相同數據的次數。完全沒問題的,因為電腦中有記憶體做這件事,我們程式中也有一種類似的東西叫緩存

在程式中緩存的實現方式根據不同語言、不同框架我們可以使用的緩存系統可以不相同,但是,最後他們要做的事情都是為了提高程式的性能而生的。

如果我們來詳細分一下那就太多了,我們稍微數一下大的分類,如:頁面緩存、靜態資源緩存、資料庫緩存、開發框架緩存、記憶體緩存系統等等這些大的分類,在這些大類上的具體實現就太多了,我們這裡只討論利用開源的記憶體緩存系統構建我們項目幾乎都需要的緩存伺服器。

比較常用的緩存系統應該就是 Redis 和 Memcached 了吧。這裡不做任何這兩個技術的比較與討論,你只需要根據你使用場景選擇合適自己的就好,或者你並沒有選擇能力的時候,什麼都別說隨便用一個就行。我這裡使用的 Memcached ,請不要問為什麼不用 Redis 。

程式中緩存的實現方式

由於我們是基於 Spring 框架下實現緩存,我大致把緩存在 Spring 下集成的方式分為了三種:

  • 通過客戶端代碼實現。我稱之為「最原始版」方式
  • 利用 AOP 方式管理。就叫它「升級版」吧
  • 註釋驅動緩存方案。Spring 3.1 版本的新特性

要說哪種方式更好,我當然更偏向於註釋驅動緩存方案這種方式,因為你需要在你需要緩存的方法名上打@Cacheable、@CachePut、@CacheEvict標簽來實現返回數據緩存到伺服器。這種方式對代碼的侵入性是比較小的!這種方式有一個目前我無法解決的問題是:當你方法每次返回的數據都不一樣的時候,你緩存命中率會是多少?
也有開源組件simple-spring-memcached也是這種方式,但它的實現原理其實是 AOP 方式來管理,他也是用@ReadThroughSingleCache、@InvalidateSingleCache、@UpdateSingleCache這類的標簽來實現緩存,對程式來說也很友好,並且要比 Spring 的方式要更完美一些,但它依然沒有解決我的上述問題。

那麼我要解決的問題是:緩存命中率要高、緩存數據要儘量少,換句話說就是儘可能少的存儲緩存數據並儘可能大的命中緩存。

如果解決我這種事兒逼的要求,那隻能自己要實現緩存咯。這就是我們上述所說的「最原始版」方式,怎麼理解這種方式,就是自己寫代碼定義一個緩存管理器,調用緩存客戶端實現緩存管理,然後再定義你要緩存的 Model 類,接著新增一個這個類的緩存實現,就是對象的獲取、增加、修改和刪除,接著就是在你需要獲取數據的時候通過緩存獲取,修改數據的時候更新緩存,刪除數據的時候刪除緩存。這種方式好不好?不好,首先它對代碼的侵入性已經到了令人髮指的地步,你想想,如果你刪除數據時不小心忘記調用刪除緩存了,那後果是什麼呢?但是,它唯一好處可能就是比較靈活了吧,可以緩存我們想緩存的內容,來解決我們上述問題,所以,思來想去最終還是決定採用最原始的方式來實現緩存,當然,首先還是要考慮我們怎麼做到緩存對代碼的侵入性,以及我們怎麼更方便或者說不需要改代碼就實現緩存了。

總結一下

這篇文章完全沒有所謂的「乾貨」,整篇都是我關於緩存的思考與選擇,如果你堅持看到這裡,那你必有一個錦繡前程。但我認為這個過程很重要,甚至會比寫出代碼還要重要,所以我選擇記錄下來,大家一起探討。

下一篇 從零開始學 Java - Spring 集成 Memcached 配置(二) 文章會寫關於緩存客戶端(Memcached Client for Java、SpyMemcached、XMemcached)的選擇和一些配置及具體代碼的實現,就是所謂的「乾貨」,如果你有興趣可以去我的 GitHub 上關於 Spring 的示例項目看看:https://github.com/mafly/SpringDemo/tree/memcached

好了,我睡了。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 原文鏈接:http://www.c-sharpcorner.com/UploadFile/3d39b4/crud-operations-using-the-generic-repository-pattern-and-dep/ 系列目錄: Relationship in Entity Framewo ...
  • 最近使用Castle.ActiveRecord框架,網上關於多數據支持的文章很少,因此有了這篇博文的產生。 開發工具VS2015,Sql Server2008R2 新建資料庫,數據初始化腳本如下: 3.新建MVC項目ActiveRecord.Demo,新建類庫Castle.ActiveRecord. ...
  • 在C#程式中,經常會有一些耗時較長的CPU密集型運算,如果直接在 UI 線程執行這樣的運算就會出現UI不響應的問題。解決這類問題的主要途徑是使用多線程,啟動一個後臺線程,把運算操作放在這個後臺線程中完成。但是原生介面的線程操作有一些難度,如果要更進一步的去完成線程間的通信就會難上加難。 還好 .NE ...
  • datagridview編輯列時,對於類中類的屬性綁定,嘗試了一下”類名.屬性名“ 並沒有正確綁定,後又嘗試了幾次無果,只能利用Linq來解決了, 首先,datagridview要綁定的是學生類(Student),而學生類里有老師類(Teacher) 正常是這樣:datagridview.Datas ...
  • 內置對象:用於頁面之間的數據交互 為什麼要使用這麼內置對象?因為HTTP的無狀態性。 Session:在電腦中,尤其是在網路應用中,稱為“會話控制”。Session 對象存儲特定用戶會話所需的屬性及配置信息。這樣,當用戶在應用程式的 Web 頁之間跳轉時,存儲在 Session 對象中的變數將不會 ...
  • Session:在不同的瀏覽器之間傳值,像銀行之類的網站為了安全把用戶名密碼保存在session裡面。每一臺電腦訪問伺服器,都會是獨立的一套session,key值都一樣,但是內容都是不一樣的 以上所有內容,都跟cookies一樣 不一樣:1、Session的保存位置是保存在伺服器上2、Sessio ...
  • 一、深入.NET框架 1..NET框架具有兩個組件:CLR(公共語言運行時)和FCL(框架類庫),CLR是.NET框架的基礎 2.框架核心類庫: System.Collections.Generic:泛型操作 System.IO:IO流操作 System.Net:網路編程 System.Data:A ...
  • ASP.NET HTTP 處理程式是響應對 ASP.NET Web 應用程式的請求而運行的過程(通常稱為"終結點")。最常用的處理程式是處理 .aspx 文件的 ASP.NET 頁處理程式。用戶請求 .aspx 文件時,頁通過頁處理程式來處理請求。 ASP.NET 頁處理程式僅僅是一種類型的處理程式 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...