普遍使用的緩存技術
數據緩存:這裡所說的數據緩存是指數據庫查詢緩存,每次訪問頁面的時候,都會先檢測相應的緩存數據是否存在,如果不存在,就連接數據庫,得到數據,並把查詢結果序列化後保存到文件
中,以後同樣的查詢結果就直接從緩存文件中獲得。
頁面緩存:
每次訪問頁面的時候,都會先檢測相應的緩存頁面文件是否存在,如果不存在,就連接數據庫,得到數據,顯示頁面並同時生成緩存頁面文件,這樣下次訪問的時候頁面文件就發揮作用了。(模板引擎和網上常見的一些緩存類通常有此功能)
內存緩存:
在裡就不介紹了,不是本文所要討論的,只簡單提一下:
Memcached是高性能的,分布式的內存對象緩存系統,用於在動態應用中減少數據庫負載,提升訪問速度。
dbcached 是一款基於 Memcached 和 NMDB 的分布式 key-value 數據庫內存緩存系統。
以上的緩存技術雖然能很好的解決頻繁查詢數據庫的問題,但其缺點在在於數據無時效性,下面我給出我在項目中常用的方法:
時間觸發緩存:
檢查文件是否存在並且時間戳小於設置的過期時間,如果文件修改的時間戳比當前時間戳減去過期時間戳大,那麼就用緩存,否則更新緩存。
設定時間內不去判斷數據是否要更新,過了設定時間再更新緩存。以上只適合對時效性要求不高的情況下使用 ,否則請看下面。
內容觸發緩存:
當插入數據或更新數據時,強制更新緩存。
在這裡我們可以看到,當有大量數據頻繁需要更新時,最後都要涉及磁盤讀寫操作。怎麼解決呢?我在日常項目中,通常並不緩存所有內容,而是緩存一部分不經常變的內容來解決。但在大負荷的情況下,最好要用共享內存做緩存系統。
到這裡PHP緩存也許有點解決方案了,但其缺點是,因為每次請求仍然要經過PHP解析,在大負荷的情況下效率問題還是比效嚴重,在這種情況下,也許會用到靜態緩存。
靜態緩存
這裡所說的靜態緩存是指Html緩存,HTML緩存一般是無需判斷數據是否要更新的,因為通常在使用HTML的場合一般是不經常變動內容的頁面。數據更新的時候把Html也強制更新一下就可以了。
其實一個緩存系統涉及的問題是比較多的,我在這裡只介紹一下我平時的緩存思路,並沒有介紹利用軟件來實現緩存和寫出具體代碼。
如果您有什麼好的解決方案也請在下面提出,讓我們一起互相探討。