應用程式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
  • 移動開發(一):使用.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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...