Asp.Net 網(wǎng)站性能優(yōu)化之緩字決 (上) 緩沖寫數(shù)據(jù)
更新時間:2010年06月09日 20:40:56 作者:
通常情況下Asp.Net 網(wǎng)站的底層數(shù)據(jù)存儲都是關(guān)系數(shù)據(jù)庫,關(guān)系數(shù)據(jù)庫資源比較昂貴,而且也很容易造成瓶頸。緩字決文章就是為大家介紹如何有效使用緩存,異步寫緩沖數(shù)據(jù)庫的壓力,從而保證網(wǎng)站的性能。
大家已經(jīng)看到很多關(guān)于Asp.Net緩存的文章了。所以我寫的時候要改變一下思路,從緩沖寫數(shù)據(jù)開始說起。緩沖寫數(shù)據(jù)的意思是在數(shù)據(jù)需要更新時不馬上把數(shù)據(jù)存到數(shù)據(jù)庫,而是先緩沖一下,然后在適當?shù)臅r機再寫入到數(shù)據(jù)庫中。
緩沖寫數(shù)據(jù)可以避免在網(wǎng)站并發(fā)訪問多的時候,數(shù)據(jù)庫瞬間承受過大壓力,而造成死鎖或響應不及時的情況。
那么什么時候適合緩沖寫呢?是不是所有情況都適用呢?緩沖寫會導致數(shù)據(jù)在內(nèi)存中或者web server硬盤或者第三方存儲中駐留一段時間,在這段時間內(nèi)如果從數(shù)據(jù)庫中查詢最新數(shù)據(jù)的話,會有遺漏。大多數(shù)事物都有兩面性,我們需要學會趨利避害;換句話說在保證緩沖寫不會導致用戶感覺數(shù)據(jù)缺少的情況下,或者在使用適當措施不讓用戶感覺數(shù)據(jù)缺失的情況下就可以使用緩沖寫。我有兩個具體的實例來介紹如何使用緩沖寫:
1. Pv(頁面瀏覽量)統(tǒng)計,大多數(shù)網(wǎng)站都有這個功能,有些網(wǎng)站還專門做這個服務
網(wǎng)站每有一個頁面被瀏覽時,就會需要給對應頁面的Pv+1;這種情況下,如果直接更新到數(shù)據(jù)庫中,訪問量稍微大一些就會造成數(shù)據(jù)庫壓力過大的問題。
所以我們需要對Pv計數(shù)做緩沖,在單web server的情況下我們可以在內(nèi)存中維護一個hashtable,然后用一個異步的線程去定時掃描這個hashtable,當點擊數(shù)達到“一定數(shù)字”時更新到數(shù)據(jù)庫。聽上去很簡單,不過也需要一個小技巧,上一句話中說的“一定數(shù)字”四個字不能是隨便的一個數(shù)字,如果它是4,試想一下會出現(xiàn)什么情況,我們的所有Pv數(shù)都會是4的倍數(shù),用戶會懷疑我們是不是在Pv上造假了;我們沒有造假卻留下了造假的跡象!這個“一定數(shù)字”必須是一個素數(shù),我們可以取7,也可以用13,如果我們的訪問量很大也可以取23或31;這樣就不會出現(xiàn)“造假的跡象”了。
2. 發(fā)送站內(nèi)短消息
站內(nèi)短消息也是一個比較通用的模塊,他可以說是一種離線消息,并非im即時消息,所以我們可以利用這個業(yè)務特性, 來對發(fā)消息做下緩沖。當有短消息發(fā)送時我們可以先將這個短消息放到硬盤文件中,然后很快的響應用戶,在ui上告訴用戶,你的消息已經(jīng)發(fā)出去了,然后我們可以用另一個線程(或者做一個windows服務)去監(jiān)視緩沖短消息的目錄順序的將短消息存儲到數(shù)據(jù)庫中。
以上兩個場景都是比較經(jīng)典的利用緩沖寫的例子,在現(xiàn)實中需要我們?nèi)ゾ唧w分析業(yè)務和某個業(yè)務是否會造成數(shù)據(jù)庫壓力來決定是否緩沖寫,如果業(yè)務本身對數(shù)據(jù)庫的壓力就很小,那當然就沒必要考慮了,反之如果業(yè)務壓力較大我們就需要做一些工作避免緩沖寫的問題并利用緩沖寫。
請尊重作者的勞動,轉(zhuǎn)載請保留鏈接 玉開的技術(shù)博客
緩沖寫數(shù)據(jù)可以避免在網(wǎng)站并發(fā)訪問多的時候,數(shù)據(jù)庫瞬間承受過大壓力,而造成死鎖或響應不及時的情況。
那么什么時候適合緩沖寫呢?是不是所有情況都適用呢?緩沖寫會導致數(shù)據(jù)在內(nèi)存中或者web server硬盤或者第三方存儲中駐留一段時間,在這段時間內(nèi)如果從數(shù)據(jù)庫中查詢最新數(shù)據(jù)的話,會有遺漏。大多數(shù)事物都有兩面性,我們需要學會趨利避害;換句話說在保證緩沖寫不會導致用戶感覺數(shù)據(jù)缺少的情況下,或者在使用適當措施不讓用戶感覺數(shù)據(jù)缺失的情況下就可以使用緩沖寫。我有兩個具體的實例來介紹如何使用緩沖寫:
1. Pv(頁面瀏覽量)統(tǒng)計,大多數(shù)網(wǎng)站都有這個功能,有些網(wǎng)站還專門做這個服務
網(wǎng)站每有一個頁面被瀏覽時,就會需要給對應頁面的Pv+1;這種情況下,如果直接更新到數(shù)據(jù)庫中,訪問量稍微大一些就會造成數(shù)據(jù)庫壓力過大的問題。
所以我們需要對Pv計數(shù)做緩沖,在單web server的情況下我們可以在內(nèi)存中維護一個hashtable,然后用一個異步的線程去定時掃描這個hashtable,當點擊數(shù)達到“一定數(shù)字”時更新到數(shù)據(jù)庫。聽上去很簡單,不過也需要一個小技巧,上一句話中說的“一定數(shù)字”四個字不能是隨便的一個數(shù)字,如果它是4,試想一下會出現(xiàn)什么情況,我們的所有Pv數(shù)都會是4的倍數(shù),用戶會懷疑我們是不是在Pv上造假了;我們沒有造假卻留下了造假的跡象!這個“一定數(shù)字”必須是一個素數(shù),我們可以取7,也可以用13,如果我們的訪問量很大也可以取23或31;這樣就不會出現(xiàn)“造假的跡象”了。
2. 發(fā)送站內(nèi)短消息
站內(nèi)短消息也是一個比較通用的模塊,他可以說是一種離線消息,并非im即時消息,所以我們可以利用這個業(yè)務特性, 來對發(fā)消息做下緩沖。當有短消息發(fā)送時我們可以先將這個短消息放到硬盤文件中,然后很快的響應用戶,在ui上告訴用戶,你的消息已經(jīng)發(fā)出去了,然后我們可以用另一個線程(或者做一個windows服務)去監(jiān)視緩沖短消息的目錄順序的將短消息存儲到數(shù)據(jù)庫中。
以上兩個場景都是比較經(jīng)典的利用緩沖寫的例子,在現(xiàn)實中需要我們?nèi)ゾ唧w分析業(yè)務和某個業(yè)務是否會造成數(shù)據(jù)庫壓力來決定是否緩沖寫,如果業(yè)務本身對數(shù)據(jù)庫的壓力就很小,那當然就沒必要考慮了,反之如果業(yè)務壓力較大我們就需要做一些工作避免緩沖寫的問題并利用緩沖寫。
請尊重作者的勞動,轉(zhuǎn)載請保留鏈接 玉開的技術(shù)博客
相關(guān)文章
.NET Core單文件發(fā)布靜態(tài)編譯AOT CoreRT的方法詳解
這篇文章主要給大家介紹了關(guān)于.NET Core單文件發(fā)布靜態(tài)編譯AOT CoreRT的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2018-07-07asp.net web頁面元素的多語言化(多國語化)實現(xiàn)分享
開發(fā)的一些系統(tǒng),經(jīng)常要求支持多語言(例如日文,英文等),接下來介紹如何實現(xiàn)asp.net開發(fā)中web頁面實現(xiàn)頁面元素的多語言化(多國語化)感興趣的朋友可以了解下,或許對你學習有所幫助2013-02-02Entity?Framework?Core生成數(shù)據(jù)庫表
這篇文章介紹了Entity?Framework?Core生成數(shù)據(jù)庫表的方法,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-03-03詳解在Azure上部署Asp.NET Core Web App
這篇文章主要介紹了詳解在Azure上部署Asp.NET Core Web App,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-12-12