程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> 深入eAccelerator與memcached的區別詳解

深入eAccelerator與memcached的區別詳解

編輯:PHP綜合

eAccelerator和memcached,是目前較為主流的兩個可使用在PHP之中的緩存加速工具.
eAccelerator專門為PHP開發,而memcached不僅僅用在PHP之中,其他所有的語言都可以使用.

eAccelerator的主要功能:

1. 緩存PHP文件的執行代碼:在被緩存的代碼再次被調用時,將直接從內存讀取,從而在很大程度了PHP運行的速度.

2. 提供了共享內存操作函數:用戶可以將自己的常見非資源對像,保存到內存之中,並可以隨時讀取出來.

memcached的主要功能:

提供共享內存操作函數,可以保存和讀取數據

兩者的共同點:

共同點:都提供了共享內存操作函數,可以用來保存和讀取自己的數據

兩者的區別:
eAccelerator作為PHP的擴展庫存在,那麼僅在PHP運行時,可以操作和讀寫共享內存,一般情況,只能由操作共享內存的程序自己調用.

同時,eAccelerator可以緩存PHP程序的執行代碼,提升程序的調入和執行速度.

memcached主要作為一個共享內存服務器,其PHP擴展庫僅僅作為PHP到memcached的連接庫存在,類似MySQL擴展庫.因而,memcached可以完全脫離PHP,其共享的數據,可以被不同的程序調用.

根據兩者的不同,我們將他們使用在真真需要的地方:

eAccelerator主要用於單機PHP提速,緩存中間數據.對於實時性高,但數據操作量小的情況下,非常實用.

memcached用於分布式或者集群系統,多台服務器可以共享數據.對於實時性高,同時數據操作量大的情況下,非常實用.

對MemCached的正確認識

剛開始,聽說用MemCached來緩存數據到內存,然後對數據進行操作,(這裡的操作包括了,查詢和更新),聽起來真是太棒了。這樣,一定時間內不用操作數據庫。真是太好了。

然後我一直在想一個問題,查詢確實可以,可是更新內存要怎麼處理並發?難道,我們的MemCached 來有這般功能,如果這樣,那真是太神了。

可是事情,並不是像說的那樣。對MemCached的這樣認識是不正確的。

MemCache和其他的cache是一樣的,當數據更新之後,cached 的東西,也就是 out date 的東西了。

在網上看了,前輩們對MemCached的闡述,更是說明了這點。

所以,不應該指望,直接更新MemCached,而省略了數據庫這一環節。

這前認為 他提供的set方法是用來更新數據庫的,那時自己的癡心妄想。

其實這個方法是將數據庫中的記錄緩存到MemCached中,同時指定它的有效期是多長。

現在我想到了,為什麼,我們的MemCached中的內容一直都沒變化,即使我已經刪除了該條記錄。

我們在set()的時候,並沒有設置它的過期時間,也就默認是0,即永不過期。只要MemCached服務器沒有重起,它就一直存在。

這樣說來,我們的ROR項目中,使用緩存來減少數據庫的檢索,而不能指望讓MemCached可以讓我們連更新數據庫也免了。

如果真的連更新數據庫也免了,就真的跨入了非數據庫時代,哈哈。估計不太可能。如果我們能保證用戶是以隊列的方式 ,一個接著一個來的話。

還是另想辦法來減輕更新帶來的壓力。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved