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可以讓我們連更新數據庫也免了。
如果真的連更新數據庫也免了,就真的跨入了非數據庫時代,哈哈。估計不太可能。如果我們能保證用戶是以隊列的方式 ,一個接著一個來的話。
還是另想辦法來減輕更新帶來的壓力。