應用程式Cache對象到高性能Memcached學習之路

来源:http://www.cnblogs.com/codelir/archive/2016/03/19/5296632.html
-Advertisement-
Play Games

來源:微信公眾號CodeL 以下是個人學習之路的簡單分享,不足之處歡迎大神們批評指正! 在網站開發的初期,我們沒有考慮更多的東西,也沒有對緩存進行系統的設計,而是直接使用了應用程式緩存對象Cache,但由於系統架構的不斷完善,在分散式系統架構中只依靠Cache明顯不夠,無法實現分散式管理,所以後期我


來源:微信公眾號CodeL

 

以下是個人學習之路的簡單分享,不足之處歡迎大神們批評指正!

在網站開發的初期,我們沒有考慮更多的東西,也沒有對緩存進行系統的設計,而是直接使用了應用程式緩存對象Cache,但由於系統架構的不斷完善,在分散式系統架構中只依靠Cache明顯不夠,無法實現分散式管理,所以後期我們採用了Memcached高性能分散式記憶體緩存伺服器。

一、應用程式緩存對象Cache

一開始,我們只處理了數據的緩存,緩存和應用程式在一臺伺服器:

應用程式先去讀緩存,若沒有數據則去讀資料庫,然後存入緩存,若有數據則無需再讀庫,對於Web網站來說,Cache的確可以使性能得到很大提高,在開始的短期時間內,我們也一直使用著Cache,但由於架構的演進,漸漸的出現了一系列的問題:

1. 緩存訪問範圍只能是當前應用程式池,對於分散式Web站點無法實現緩存的統一管理,往往只能在A站添加一份,B站也添加一份,無法共用緩存資源,這樣非常不合理,同時也非常浪費資源。

2. 緩存和應用程式無法分離,無法分散式部署,IIS吃記憶體已經是非常厲害了,常常導致緩存溢出,且每次更新程式都會導致緩存丟失。

3.緩存管理難度加大,需要對每個站點進行單獨的管理。綜上,後期由於網站的訪問量增加,為解決伺服器資源等各方面性能問題,我們不得不將緩存和Web伺服器獨立開來分開管理,於是我們採用了Memcached分散式緩存。

 

二、Memcached高性能分散式緩存

使用Memcached緩存之後,我們並沒有拋棄應用程式Cache,而是用它來做動態頁面輸出緩存:

使用Memcached後的緩存設計:    

【 IIS伺服器 or 其他代理伺服器】(記憶體) :動態頁面緩存    

【MemCached】(記憶體):數據緩存    

【瀏覽器緩存】(硬碟):動態/靜態頁面緩存,靜態文件(圖片,js,css)
我們通過Memcached實現了緩存的分散式管理,同樣我們只對資料庫數據進行緩存處理,對於閑下來的Cache我們用它做了少量的動態頁面輸出緩存:

【斷絕發送請求至伺服器】的過程  : 

   1.OutputCache  :類型Any——頁面被緩存在瀏覽器、代理伺服器端和web伺服器端   

   2.http標頭Cache-Control :處理點擊“轉到”或者游標移入地址欄然後回車,不發送請求至伺服器 

   3.http標頭Last-Modified:用來處理F5刷新的,也就是對Last-Modified有效,需要請求伺服器判斷是否載入新的內容

 

緩存用於在動態應用中減少資料庫負載,更好的分配資源,提升訪問速度。是開發中必須學習的技術,這裡給大家簡單介紹了我在開發中使用緩存的一些經歷,對於Web性能優化方面,我們除了優化緩存設計之外,也需要儘量減少對伺服器的http請求,包括之前提到的延遲載入,動態合併js/css文件等方法,希望對初學者有所幫助。

以上是個人學習之路的簡單分享,不足之處歡迎大神們指正!

技術類公眾號推薦:CodeL

 


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

-Advertisement-
Play Games
更多相關文章
  • 作用: 在需要引入的頭文件比較多的時候可以使用, 創建成功之後,引入頭文件.之後再使用的時候不需要引入頭文件 步驟: 1.創建一個這樣的文件 2.進行一下設置 路徑的設置 修改為yes,預編譯這個文件 3.報錯時候的解決 原因是上邊的路徑錯誤.重新設置路徑 錯誤提示
  • 本文由ilanniweb提供友情贊助,首發於爛泥行天下 想要獲得更多的文章,可以關註我的微信ilanniweb 在前一篇文章《爛泥:Postfix郵件伺服器搭建之軟體安裝與配置》中,我們介紹了psotfix郵件伺服器搭建所需要的軟體,以及各個軟體的基本配置。 目前已經達到了通過系統用戶可以登錄到po...
  • 1.1二進位包安裝MySQL資料庫 1.1.1 安裝前準備(規範) 1.1.2 初始化資料庫 1.1.3 授權Mysql管理資料庫文件 1.1.4 生成Mysql配置文件 1.1.5 配置啟動Mysql 1.1.6 啟動Mysql 1.1.7 配置環境變數 方法1: 方法2: 1.1.8 設置及更改
  • 推薦一本不錯的書籍,《電子設計從零開始》(楊欣)。通讀此書,通俗易懂,還結合multisim進行模擬驗證。對本科階段的模電書籍是一種顛覆。 以下截取自裡面部分章節,如何計算共射極放大電路的各個參數。很實用。 1.Vcq為集電極的靜態工作電壓,Vcq的選取為了避免出現飽和和截止失真,使Vcq ≈ 1/
  • 系統來自:系統媽:http://www.xitongma.com 新蘿蔔家園GHOST win7系統32位極速裝機特別版 V2016年3月 系統概述 新蘿蔔家園ghost win7系統32位極速裝機特別版加快“網上鄰居”共用速度;取消不需要的網路服務組件,系統支持Windows安裝,可以在Windo
  • 文件和目錄 命令 選項 註解 示例 文件的基本操作 ls [選項][文件] 顯示所有文件和目錄 ls -al -a(A) 顯示所有文件和目錄,包括隱藏文件和目錄(顯示所有文件和目錄,包括隱藏文件和目錄,但不現實“.”和“..”目錄) 查看當前目錄下的所有文件的詳細信息=ll -l 顯示文件和目錄的完
  • 學習linux時候的基礎,第一部分,常用命令
  • OWIN源碼,Katana project
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...