使用memcache的session入庫(kù)
Memcached是一款開(kāi)源、高性能、分布式內(nèi)存對(duì)象緩存系統(tǒng),可應(yīng)用各種需要緩存的場(chǎng)景,其主要目的是通過(guò)降低對(duì)Database的訪問(wèn)來(lái)加速web應(yīng)用程序。它是一個(gè)基于內(nèi)存的"鍵值對(duì)"存儲(chǔ),用于存儲(chǔ)數(shù)據(jù)庫(kù)調(diào)用、API調(diào)用或頁(yè)面引用結(jié)果的直接數(shù)據(jù),如字符串、對(duì)象等。
memcached是以LiveJournal旗下Danga Interactive 公司的Brad Fitzpatric 為首開(kāi)發(fā)的一款軟件。現(xiàn)在已成為mixi、hatena、Facebook、Vox、LiveJournal等眾多服務(wù)中提高Web應(yīng)用擴(kuò)展性的重要因素。
Memcached是一款開(kāi)發(fā)工具,它既不是一個(gè)代碼加速器,也不是數(shù)據(jù)庫(kù)中間件。其設(shè)計(jì)哲學(xué)思想主要反映在如下方面:
- 簡(jiǎn)單key/value存儲(chǔ):服務(wù)器不關(guān)心數(shù)據(jù)本身的意義及結(jié)構(gòu),只要是可序列化數(shù)據(jù)即可。存儲(chǔ)項(xiàng)由“鍵、過(guò)期時(shí)間、可選的標(biāo)志及數(shù)據(jù)”四個(gè)部分組成;
- 功能的實(shí)現(xiàn)一半依賴于客戶端,一半基于服務(wù)器端:客戶負(fù)責(zé)發(fā)送存儲(chǔ)項(xiàng)至服務(wù)器端、從服務(wù)端獲取數(shù)據(jù)以及無(wú)法連接至服務(wù)器時(shí)采用相應(yīng)的動(dòng)作;服務(wù)端負(fù)責(zé)接收、存儲(chǔ)數(shù)據(jù),并負(fù)責(zé)數(shù)據(jù)項(xiàng)的超時(shí)過(guò)期;
- 各服務(wù)器間彼此無(wú)視:不在服務(wù)器間進(jìn)行數(shù)據(jù)同步;
- O(1)的執(zhí)行效率
- 清理超期數(shù)據(jù):默認(rèn)情況下,Memcached是一個(gè)LRU緩存,同時(shí),它按事先預(yù)訂的時(shí)長(zhǎng)清理超期數(shù)據(jù);但事實(shí)上,memcached不會(huì)刪除任何已緩存數(shù)據(jù),只是在其過(guò)期之后不再為客戶所見(jiàn);而且,memcached也不會(huì)真正按期限清理緩存,而僅是當(dāng)get命令到達(dá)時(shí)檢查其時(shí)長(zhǎng);
Memcached提供了為數(shù)不多的幾個(gè)命令來(lái)完成與服務(wù)器端的交互,這些命令基于memcached的協(xié)議實(shí)現(xiàn)。
存儲(chǔ)類命令:set, add, replace, append, prepend
獲取數(shù)據(jù)類命令:get, delete, incr/decr
統(tǒng)計(jì)類命令:stats, stats items, stats slabs, stats sizes
清理命令: flush_all
一、安裝libevent
memcached依賴于libevent API,因此要事先安裝之,項(xiàng)目主頁(yè):http://libevent.org/,可自行選擇需要的版本下載。本文采用的是目前最新版本的源碼包libevent-2.0.16-stable.tar.gz。安裝過(guò)程:
# tar xf libevent-2.0.20-stable.tar.gz
# cd libevent-2.0.20
# ./configure --prefix=/usr/local/libevent
# make && make install
# echo "/usr/local/libevent/lib" > /etc/ld.so.conf.d/libevent.conf
# ldconfig
二、安裝配置memcached,也可以使用rpm包安裝,可以開(kāi)啟安全的驗(yàn)證 sasl
1、安裝memcached
# tar xf memcached-1.4.15.tar.gz
# cd memcached-1.4.15
# ./configure --prefix=/usr/local/memcached --with-libevent=/usr/local/libevent
# make && make install
注意事項(xiàng):
items.c: In function ‘crawler_crawl_q’:
items.c:1141: warning: comparison is always true due to limited range of data type
make[2]: *** [memcached_debug-items.o] Error 1
make[2]: Leaving directory `/usr/local/src/memcached-1.4.24'
make[1]: *** [all-recursive] Error 1
make[1]: Leaving directory `/usr/local/src/memcached-1.4.24'
make: *** [all] Error 2
解決方案:編輯Makefile文件,刪除文件中的 " -Werror ",保存后即可
2、memcached SysV的startup腳本代碼如下所示,將其建立為/etc/init.d/memcached文件:
#!/bin/bash
#
# Init file for memcached
#
# chkconfig: - 86 14
# description: Distributed memory caching daemon
#
# processname: memcached
# config: /etc/sysconfig/memcached
. /etc/rc.d/init.d/functions
## Default variables
PORT="11211"
USER="nobody"
MAXCONN="1024"
CACHESIZE="64"
OPTIONS=""
# Add memcache configure
[ -f /etc/sysconfig/memcachd ] && . /etc/sysconfig/memcached
RETVAL=0
prog="/usr/local/memcached/bin/memcached"
desc="Distributed memory caching"
lockfile="/var/lock/subsys/memcached"
start() {
echo -n $"Starting $desc (memcached): "
daemon $prog -d -p $PORT -u $USER -c $MAXCONN -m $CACHESIZE $OPTIONS
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && touch $lockfile
return $RETVAL
}
stop() {
echo -n $"Shutting down $desc (memcached): "
killproc $prog
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && rm -f $lockfile
return $RETVAL
}
restart() {
stop
start
}
reload() {
echo -n $"Reloading $desc ($prog): "
killproc $prog -HUP
RETVAL=$?
echo
return $RETVAL
}
case "$1" in
start)
start
;;
stop)
stop
;;
restart)
restart
;;
condrestart)
[ -e $lockfile ] && restart
RETVAL=$?
;;
reload)
reload
;;
status)
status $prog
RETVAL=$?
;;
*)
echo $"Usage: $0 {start|stop|restart|condrestart|status}"
RETVAL=1
esac
exit $RETVAL
使用如下命令配置memcached成為系統(tǒng)服務(wù):
# chmod +x /etc/init.d/memcached
# chkconfig --add memcached
# service memcached start
3、使用telnet命令測(cè)試memcached的使用
Memcached提供一組基本命令用于基于命令行調(diào)用其服務(wù)或查看服務(wù)器狀態(tài)等。
# telnet 127.0.0.1 11211
add命令:
add keyname flag timeout datasize
如:
add mykey 0 10 12
Hello world!
get命令:
get keyname
如:get mykey
VALUE mykey 0 12
Hello world!
END
可以telnet 后使用stats 查看使用內(nèi)存
4、memcached的常用選項(xiàng)說(shuō)明
-l :指定進(jìn)程監(jiān)聽(tīng)的地址,當(dāng)有多個(gè)網(wǎng)卡的時(shí)候;
-d: 以服務(wù)模式運(yùn)行;
-u :以指定的用戶身份運(yùn)行memcached進(jìn)程;
-m :用于緩存數(shù)據(jù)的最大內(nèi)存空間,單位為MB,默認(rèn)為64MB;
-c :最大支持的并發(fā)連接數(shù),默認(rèn)為1024;
-p : 指定監(jiān)聽(tīng)的TCP端口,默認(rèn)為11211;
-U :指定監(jiān)聽(tīng)的UDP端口,默認(rèn)為11211,0表示關(guān)閉UDP端口;
-t :用于處理入站請(qǐng)求的最大線程數(shù),僅在memcached編譯時(shí)開(kāi)啟了支持線程才有效;
-f :設(shè)定Slab Allocator定義預(yù)先分配內(nèi)存空間大小固定的塊時(shí)使用的增長(zhǎng)因子;
-M:當(dāng)內(nèi)存空間不夠使用時(shí)返回錯(cuò)誤信息,而不是按LRU算法利用空間;
-n: 指定最小的slab chunk大小;單位是字節(jié);
-S: 啟用sasl進(jìn)行用戶認(rèn)證;
三、安裝Memcache的PHP擴(kuò)展
①安裝PHP的memcache擴(kuò)展
# tar xf memcache-2.2.5.tgz
# cd memcache-2.2.5
/usr/local/php/bin/phpize
# ./configure --with-php-config=/usr/local/php/bin/php-config --with-memcache
# make && make install
上述安裝完后會(huì)有類似以下的提示:
Installing shared extensions: /usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/
②編輯/usr/local/php/lib/php.ini,在“動(dòng)態(tài)模塊”相關(guān)的位置添加如下一行來(lái)載入memcache擴(kuò)展:
extension=/usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/memcache.so
而后對(duì)memcached功能進(jìn)行測(cè)試,在網(wǎng)站目錄中建立測(cè)試頁(yè)面test.php,添加如下內(nèi)容:
connect("127.0.0.1", 11211) or die("Could not connect");
$version = $mem->getVersion();
echo "Server's version: ".$version."
\n";
$mem->set('testkey', 'Hello World', 0, 600) or die("Failed to save data at the memcached server");
echo "Store data in the cache (data will expire in 600 seconds)
\n";
$get_result = $mem->get('testkey');
echo "$get_result is from memcached server.";
?>
如果有輸出“Hello World is from memcached.”等信息,則表明memcache已經(jīng)能夠正常工作。
四、使用libmemcached的客戶端工具:
訪問(wèn)memcached的傳統(tǒng)方法是使用基于perl語(yǔ)言開(kāi)發(fā)的Cache::memcached模塊,這個(gè)模塊在大多數(shù)perl代碼中都能良好的工作,但也有著眾所周知的性能方面的問(wèn)題。libMemcached則是基于C語(yǔ)言開(kāi)發(fā)的開(kāi)源的C/C++代碼訪問(wèn)memcached的庫(kù)文件,同時(shí),它還提供了數(shù)個(gè)可以遠(yuǎn)程使用的memcached管理工具,如memcat, memping,memstat,memslap等。
-
編譯安裝libmemcached
tar xf libmemcached-1.0.2.tar.gz
cd libmemcached-1.0.2
./configure
make && make install
ldconfig
-
客戶端工具
memcat --servers=127.0.0.1:11211 mykey
memping
memslap
memstat
基于web界面的管理 memadmin
五、將session回話信息保存到memcache里面
-
更改PHP的配置文件php.ini,增加如下配置信息
session.save_handler = memcache session.save_path ="tcp://127.0.0.1:11211"