Memcached 安裝配置

Memcached 安裝配置

[toc]

前言:

Memcached是一款開源、高性能、分布式內(nèi)存對(duì)象緩存系統(tǒng),可應(yīng)用各種需要緩存的場(chǎng)景伦仍,其主要目的是通過降低對(duì)Database的訪問來加速web應(yīng)用程序结窘。它是一個(gè)基于內(nèi)存的“鍵值對(duì)”存儲(chǔ)很洋,用于存儲(chǔ)數(shù)據(jù)庫(kù)調(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特性

Memcached是一款開發(fā)工具,它既不是一個(gè)代碼加速器妖滔,也不是數(shù)據(jù)庫(kù)中間件隧哮。其設(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內(nèi)置操作命令

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本身在客戶端連接的時(shí)候是使用事件驅(qū)動(dòng)(event-driven),它利用的是libevent這個(gè)庫(kù)齿税。(也就是說libevent這個(gè)庫(kù)可以提供event-driven(事件驅(qū)動(dòng))這樣的功能)

memcached依賴于libevent API彼硫,因此要事先安裝之,項(xiàng)目主頁:http://libevent.org/,讀者可自行選擇需要的版本下載拧篮。本文采用的是目前最新版本的源碼包libevent-2.0.16-stable.tar.gz词渤。安裝過程:

rpm -q libevent //查看一下是否已經(jīng)安裝libevent庫(kù)

# wget https://cloud.github.com/downloads/libevent/libevent/libevent-2.0.20-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

1串绩、安裝memcached

# wget -O /usr/src/memcached-1.4.34.tar.gz http://www.memcached.org/files/memcached-1.4.34.tar.gz
# tar xf memcached-1.4.15.tar.gz 
# cd memcached-1.4.15
# ./configure --prefix=/usr/local/memcached --with-libevent=/usr/local/libevent --enable-sasl          
    //--enable-sasl  是啟用sasl認(rèn)證缺虐,因?yàn)閙emcached默認(rèn)不支持認(rèn)證,所以私密數(shù)據(jù)會(huì)存在安全隱患礁凡,開啟sasl認(rèn)證后高氮,memcached可以借助sasl進(jìn)行認(rèn)證。在需要的時(shí)候可以開啟此選項(xiàng)
    // 但是開啟sasl之前要確認(rèn)cyrus-sasl-devel的開發(fā)庫(kù)是否已經(jīng)安裝顷牌,沒有的話纫溃,則安裝之;
    // rpm -qa | grep sasl
    // yum list all | grep sasl
    // yum install -y cyrus-sasl-devel
# make && make install

2韧掩、創(chuàng)建memcached SysV腳本

  • 代碼如下所示紊浩,將其建立為/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=""

[ -f /etc/sysconfig/memcached ] && . /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"  #啟動(dòng)失敗,去掉-o
        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
# chkconfig memcached on
# 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

4、memcached啟動(dòng)命令及常用選項(xiàng)說明

# /usr/local/memcached/bin/memcached -d -c 1024 -m 128 -n 20 -f 1.25 -u nobody

-l <ip_addr>:指定進(jìn)程監(jiān)聽的地址滑臊;
-d: 以服務(wù)模式運(yùn)行口芍;
-u <username>:以指定的用戶身份運(yùn)行memcached進(jìn)程;
-m <num>:用于緩存數(shù)據(jù)的最大內(nèi)存空間雇卷,單位為MB鬓椭,默認(rèn)為64MB;
-c <num>:最大支持的并發(fā)連接數(shù)关划,默認(rèn)為1024小染;
-p <num>: 指定監(jiān)聽的TCP端口,默認(rèn)為11211贮折;
-U <num>:指定監(jiān)聽的UDP端口裤翩,默認(rèn)為11211,0表示關(guān)閉UDP端口调榄;
-t <threads>:用于處理入站請(qǐng)求的最大線程數(shù)踊赠,僅在memcached編譯時(shí)開啟了支持線程才有效;
-f <num>:設(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)證;
-v: 顯示詳細(xì)信息
-vv: 顯示更加詳盡的信息

三鸽斟、安裝Memcache的PHP擴(kuò)展

1. 安裝PHP的memcache擴(kuò)展

下載地址:http://pecl.php.net/package/memcache

# wget http://203.187.160.133:9011/pecl.php.net/c3pr90ntc0td/get/memcache-2.2.7.tgz
# 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 --enable-memcache --with-zlib-dir
# make && make install 

上述安裝完后會(huì)有類似以下的提示:

Installing shared extensions:     /usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/

2. 編輯/usr/local/php/etc/php.ini

在“動(dòng)態(tài)模塊”相關(guān)的位置添加如下一行來載入memcache擴(kuò)展:
extension=/usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/memcache.so

3. 測(cè)試php連接memcached

而后對(duì)memcached功能進(jìn)行測(cè)試拔创,在網(wǎng)站目錄中建立測(cè)試頁面test.php利诺,添加如下內(nèi)容:

<?php
$mem = new Memcache;
$mem->connect("127.0.0.1", 11211)  or die("Could not connect");

$version = $mem->getVersion();
echo "Server's version: ".$version."<br/>\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)<br/>\n";

$get_result = $mem->get('testkey');
echo "$get_result is from memcached server.";         
?>

如果webd頁面有輸出“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的庫(kù)文件口注,同時(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

五材部、memcache圖形化管理工具M(jìn)emAdmin

官方網(wǎng)站:http://www.junopen.com/memadmin/

wget http://203.187.160.135:9011/www.junopen.com/c3pr90ntc0td/memadmin/memadmin-1.0.12.tar.gz

將memadmin-1.0.12.tar.gz網(wǎng)站根目錄下
tar xf memadmin-1.0.12.tar.gz -C /wwwroot
[root@DH-A07-TEST ~]# cd /wwwroot/memadmin/
[root@DH-A07-TEST memadmin]# ls
apps  config.php  images  include  index.php  langs  LICENSE.txt  README.txt  view

直接在瀏覽器中訪問:
http://IP/memadmin
進(jìn)入登錄界面,默認(rèn)登錄賬號(hào)密碼都是admin,如果想修改登錄的賬號(hào)密碼唯竹,可修改如下配置文件:

# vim /wwwroot/memadmin/config.php 
$config['user'] = "duohui";     // your username
$config['passwd'] = "360duohui.cc"; // your password

六乐导、Nginx整合memcached:

server {
        listen       80;
        server_name  www.magedu.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
                set $memcached_key $uri;
                memcached_pass     127.0.0.1:11211;
                default_type       text/html;
                error_page         404 @fallback;
        }

        location @fallback {
                proxy_pass http://172.16.0.1;
        }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市浸颓,隨后出現(xiàn)的幾起案子物臂,更是在濱河造成了極大的恐慌,老刑警劉巖产上,帶你破解...
    沈念sama閱讀 218,036評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件棵磷,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡晋涣,警方通過查閱死者的電腦和手機(jī)泽本,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來姻僧,“玉大人规丽,你說我怎么就攤上這事∑埠兀” “怎么了赌莺?”我有些...
    開封第一講書人閱讀 164,411評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)松嘶。 經(jīng)常有香客問我艘狭,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,622評(píng)論 1 293
  • 正文 為了忘掉前任巢音,我火速辦了婚禮遵倦,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘官撼。我一直安慰自己梧躺,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,661評(píng)論 6 392
  • 文/花漫 我一把揭開白布傲绣。 她就那樣靜靜地躺著掠哥,像睡著了一般。 火紅的嫁衣襯著肌膚如雪秃诵。 梳的紋絲不亂的頭發(fā)上续搀,一...
    開封第一講書人閱讀 51,521評(píng)論 1 304
  • 那天,我揣著相機(jī)與錄音菠净,去河邊找鬼禁舷。 笑死,一個(gè)胖子當(dāng)著我的面吹牛毅往,可吹牛的內(nèi)容都是我干的牵咙。 我是一名探鬼主播,決...
    沈念sama閱讀 40,288評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼煞抬,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼霜大!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起革答,我...
    開封第一講書人閱讀 39,200評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤战坤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后残拐,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體途茫,經(jīng)...
    沈念sama閱讀 45,644評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,837評(píng)論 3 336
  • 正文 我和宋清朗相戀三年溪食,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了囊卜。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,953評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡错沃,死狀恐怖栅组,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情枢析,我是刑警寧澤玉掸,帶...
    沈念sama閱讀 35,673評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站醒叁,受9級(jí)特大地震影響司浪,放射性物質(zhì)發(fā)生泄漏泊业。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,281評(píng)論 3 329
  • 文/蒙蒙 一啊易、第九天 我趴在偏房一處隱蔽的房頂上張望吁伺。 院中可真熱鬧,春花似錦租谈、人聲如沸篮奄。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,889評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽宦搬。三九已至牙瓢,卻和暖如春劫拗,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背矾克。 一陣腳步聲響...
    開封第一講書人閱讀 33,011評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工页慷, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人胁附。 一個(gè)月前我還...
    沈念sama閱讀 48,119評(píng)論 3 370
  • 正文 我出身青樓酒繁,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親控妻。 傳聞我的和親對(duì)象是個(gè)殘疾皇子州袒,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,901評(píng)論 2 355

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