memcache保存session數(shù)據(jù)

使用memcache的session入庫


Memcached是一款開源增淹、高性能欧引、分布式內(nèi)存對(duì)象緩存系統(tǒng)垮媒,可應(yīng)用各種需要緩存的場(chǎng)景听系,其主要目的是通過降低對(duì)Database的訪問來加速web應(yīng)用程序贝奇。它是一個(gè)基于內(nèi)存的"鍵值對(duì)"存儲(chǔ),用于存儲(chǔ)數(shù)據(jù)庫調(diào)用靠胜、API調(diào)用或頁面引用結(jié)果的直接數(shù)據(jù)掉瞳,如字符串、對(duì)象等浪漠。

memcached是以LiveJournal旗下Danga Interactive 公司的Brad Fitzpatric 為首開發(fā)的一款軟件〔ぷ現(xiàn)在已成為mixi、hatena郑藏、Facebook衡查、Vox、LiveJournal等眾多服務(wù)中提高Web應(yīng)用擴(kuò)展性的重要因素必盖。

Memcached是一款開發(fā)工具拌牲,它既不是一個(gè)代碼加速器,也不是數(shù)據(jù)庫中間件歌粥。其設(shè)計(jì)哲學(xué)思想主要反映在如下方面:

  1. 簡(jiǎn)單key/value存儲(chǔ):服務(wù)器不關(guān)心數(shù)據(jù)本身的意義及結(jié)構(gòu)塌忽,只要是可序列化數(shù)據(jù)即可。存儲(chǔ)項(xiàng)由“鍵失驶、過期時(shí)間土居、可選的標(biāo)志及數(shù)據(jù)”四個(gè)部分組成;
  2. 功能的實(shí)現(xiàn)一半依賴于客戶端,一半基于服務(wù)器端:客戶負(fù)責(zé)發(fā)送存儲(chǔ)項(xiàng)至服務(wù)器端擦耀、從服務(wù)端獲取數(shù)據(jù)以及無法連接至服務(wù)器時(shí)采用相應(yīng)的動(dòng)作棉圈;服務(wù)端負(fù)責(zé)接收、存儲(chǔ)數(shù)據(jù)眷蜓,并負(fù)責(zé)數(shù)據(jù)項(xiàng)的超時(shí)過期分瘾;
  3. 各服務(wù)器間彼此無視:不在服務(wù)器間進(jìn)行數(shù)據(jù)同步;
  4. O(1)的執(zhí)行效率
  5. 清理超期數(shù)據(jù):默認(rèn)情況下吁系,Memcached是一個(gè)LRU緩存德召,同時(shí),它按事先預(yù)訂的時(shí)長(zhǎng)清理超期數(shù)據(jù)汽纤;但事實(shí)上上岗,memcached不會(huì)刪除任何已緩存數(shù)據(jù),只是在其過期之后不再為客戶所見蕴坪;而且液茎,memcached也不會(huì)真正按期限清理緩存,而僅是當(dāng)get命令到達(dá)時(shí)檢查其時(shí)長(zhǎng)辞嗡;

Memcached提供了為數(shù)不多的幾個(gè)命令來完成與服務(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)目主頁:http://libevent.org/挺狰,可自行選擇需要的版本下載明郭。本文采用的是目前最新版本的源碼包libevent-2.0.16-stable.tar.gz。安裝過程:

# 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包安裝镜粤,可以開啟安全的驗(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)說明

-l :指定進(jìn)程監(jiān)聽的地址,當(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)聽的TCP端口捕透,默認(rèn)為11211聪姿;
-U :指定監(jiān)聽的UDP端口碴萧,默認(rèn)為11211,0表示關(guān)閉UDP端口末购;
-t :用于處理入站請(qǐng)求的最大線程數(shù)破喻,僅在memcached編譯時(shí)開啟了支持線程才有效;
-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)的位置添加如下一行來載入memcache擴(kuò)展:
extension=/usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/memcache.so

而后對(duì)memcached功能進(jìn)行測(cè)試站欺,在網(wǎng)站目錄中建立測(cè)試頁面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的客戶端工具:

訪問memcached的傳統(tǒng)方法是使用基于perl語言開發(fā)的Cache::memcached模塊,這個(gè)模塊在大多數(shù)perl代碼中都能良好的工作贾虽,但也有著眾所周知的性能方面的問題逃糟。libMemcached則是基于C語言開發(fā)的開源的C/C++代碼訪問memcached的庫文件,同時(shí)蓬豁,它還提供了數(shù)個(gè)可以遠(yuǎn)程使用的memcached管理工具履磨,如memcat, memping,memstat庆尘,memslap等剃诅。

  1. 編譯安裝libmemcached

    tar xf libmemcached-1.0.2.tar.gz

    cd libmemcached-1.0.2

    ./configure

    make && make install

    ldconfig

  2. 客戶端工具

    memcat --servers=127.0.0.1:11211 mykey

    memping

    memslap

    memstat

  3. 基于web界面的管理 memadmin

五、將session回話信息保存到memcache里面

  1. 更改PHP的配置文件php.ini驶忌,增加如下配置信息

     session.save_handler = memcache
     session.save_path ="tcp://127.0.0.1:11211"
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末矛辕,一起剝皮案震驚了整個(gè)濱河市笑跛,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌聊品,老刑警劉巖飞蹂,帶你破解...
    沈念sama閱讀 222,464評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異翻屈,居然都是意外死亡陈哑,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,033評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門伸眶,熙熙樓的掌柜王于貴愁眉苦臉地迎上來惊窖,“玉大人,你說我怎么就攤上這事厘贼〗缇疲” “怎么了?”我有些...
    開封第一講書人閱讀 169,078評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵嘴秸,是天一觀的道長(zhǎng)毁欣。 經(jīng)常有香客問我,道長(zhǎng)岳掐,這世上最難降的妖魔是什么凭疮? 我笑而不...
    開封第一講書人閱讀 59,979評(píng)論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮串述,結(jié)果婚禮上执解,老公的妹妹穿的比我還像新娘。我一直安慰自己剖煌,他們只是感情好材鹦,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,001評(píng)論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著耕姊,像睡著了一般桶唐。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上茉兰,一...
    開封第一講書人閱讀 52,584評(píng)論 1 312
  • 那天尤泽,我揣著相機(jī)與錄音,去河邊找鬼规脸。 笑死坯约,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的莫鸭。 我是一名探鬼主播闹丐,決...
    沈念sama閱讀 41,085評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼被因!你這毒婦竟也來了卿拴?” 一聲冷哼從身側(cè)響起衫仑,我...
    開封第一講書人閱讀 40,023評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎堕花,沒想到半個(gè)月后文狱,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,555評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡缘挽,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,626評(píng)論 3 342
  • 正文 我和宋清朗相戀三年瞄崇,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片壕曼。...
    茶點(diǎn)故事閱讀 40,769評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡苏研,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出窝稿,到底是詐尸還是另有隱情楣富,我是刑警寧澤凿掂,帶...
    沈念sama閱讀 36,439評(píng)論 5 351
  • 正文 年R本政府宣布伴榔,位于F島的核電站,受9級(jí)特大地震影響庄萎,放射性物質(zhì)發(fā)生泄漏踪少。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,115評(píng)論 3 335
  • 文/蒙蒙 一糠涛、第九天 我趴在偏房一處隱蔽的房頂上張望援奢。 院中可真熱鬧,春花似錦忍捡、人聲如沸集漾。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,601評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽具篇。三九已至,卻和暖如春凌埂,著一層夾襖步出監(jiān)牢的瞬間驱显,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,702評(píng)論 1 274
  • 我被黑心中介騙來泰國(guó)打工瞳抓, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留埃疫,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,191評(píng)論 3 378
  • 正文 我出身青樓孩哑,卻偏偏與公主長(zhǎng)得像栓霜,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子横蜒,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,781評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容