天天看點

加速與緩存技術之Memcached

Memcached

Memcached是一款開源、高性能、分布式記憶體對象緩存系統,可應用各種需要緩存的場景,其主要目的是通過降低對

Database的通路來加速web應用程式。它是一個基于記憶體的“鍵值對”存儲,用于存儲資料庫調用、API調用或頁面引用結果的直接資料,如字元串、對象等。

Memcached是以LiveJournal旗下Danga Interactive 公司的Brad Fitzpatric 為首開發的一款軟體。現在已成為mixi、hatena、Facebook、Vox、LiveJournal等衆多服務中提高Web應用擴充性的重要因素。

Memcached是一款開發工具,它既不是一個代碼加速器,也不是資料庫中間件。其設計哲學思想主要反映在如下方面:

1. 簡單key/value存儲:伺服器不關心資料本身的意義及結構,隻要是可序列化資料即可。存儲項由“鍵、過期時間、可選的标志及資料”四個部分組成;

2. 功能的實作一半依賴于用戶端,一半基于伺服器端:客戶負責發送存儲項至伺服器端、從服務端擷取資料以及無法連接配接至伺服器時采用相應的動作;服務端負責接收、存儲資料,并負責資料項的逾時過期;

3. 各伺服器間彼此無視:不在伺服器間進行資料同步;

4. O(1)的執行效率

5. 清理超期資料:預設情況下,Memcached是一個LRU緩存,同時,它按事先預訂的時長清理超期資料;但事實上,memcached不會删除任何已緩存資料,隻是在其過期之後不再為客戶所見;而且,memcached也不會真正按期限清理緩存,而僅是當get指令到達時檢查其時長;

Memcached提供了為數不多的幾個指令來完成與伺服器端的互動,這些指令基于memcached的協定實作。

存儲類指令:set, add, replace, append, prepend

擷取資料類指令:get, delete, incr/decr

統計類指令:stats, stats items, stats slabs, stats sizes

清理指令: flush_all

一、安裝libevent

二、安裝配置memcached

1、安裝memcached

2、memcached SysV的startup腳本代碼如下所示,将其建立為/etc/init.d/memcahced檔案:

使用如下指令配置memcached成為系統服務:

3、使用telnet指令測試memcached的使用

Memcached提供一組基本指令用于基于指令行調用其服務或檢視伺服器狀态等。

add指令:

add keyname flag  timeout  datasize

如:

add mykey 0 10 12

Hello world!

get指令:

get keyname

如:get mykey

VALUE mykey 0 12

END

4、memcached的常用選項說明

-l <ip_addr>:指定程序監聽的位址;

-d: 以服務模式運作;

-u <username>:以指定的使用者身份運作memcached程序;

-m <num>:用于緩存資料的最大記憶體空間,機關為MB,預設為64MB;

-c <num>:最大支援的并發連接配接數,預設為1024;

-p <num>: 指定監聽的TCP端口,預設為11211;

-U <num>:指定監聽的UDP端口,預設為11211,0表示關閉UDP端口;

-t <threads>:用于處理入站請求的最大線程數,僅在memcached編譯時開啟了支援線程才有效;

-f <num>:設定Slab Allocator定義預先配置設定記憶體空間大小固定的塊時使用的增長因子;

-M:當記憶體空間不夠使用時傳回錯誤資訊,而不是按LRU算法利用空間;

-n: 指定最小的slab chunk大小;機關是位元組;

-S: 啟用sasl進行使用者認證;

三、安裝Memcache的PHP擴充

1)安裝php的memcached擴充

上述安裝完後會有類似以下的提示:

2)編輯/usr/local/php/lib/php.ini,在“動态子產品”相關的位置添加如下一行來載入memcache擴充:

而後對memcached功能進行測試,在網站目錄中建立測試頁面test.php,添加如下内容:

如果有輸出“Hello World is from memcached.”等資訊,則表明memcache已經能夠正常工作。

四、使用libmemcached的用戶端工具:

通路memcached的傳統方法是使用基于perl語言開發的Cache::memcached子產品,這個子產品在大多數perl代碼中都能良好的工作,但也有着衆所周知的性能方面的問題。libMemcached則是基于C語言開發的開源的C/C++代碼通路memcached的庫檔案,同時,它還提供了數個可以遠端使用的memcached管理工具,如memcat, memping,memstat,memslap等。

1) 編譯安裝libmemcached

2) 用戶端工具

五、Nginx整合memcached:

本文轉自 SoulMio 51CTO部落格,原文連結:http://blog.51cto.com/bovin/1853761,如需轉載請自行聯系原作者