天天看點

Memcached 安裝配置

Memcached 安裝配置

[toc]

前言:

Memcached是一款開源、高性能、分布式記憶體對象緩存系統,可應用各種需要緩存的場景,其主要目的是通過降低對Database的通路來加速web應用程式。它是一個基于記憶體的“鍵值對”存儲,用于存儲資料庫調用、API調用或頁面引用結果的直接資料,如字元串、對象等。

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

Memcached特性

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

  1. 簡單key/value存儲:伺服器不關心資料本身的意義及結構,隻要是可序列化資料即可。存儲項由“鍵、過期時間、可選的标志及資料”四個部分組成;
  2. 功能的實作一半依賴于用戶端,一半基于伺服器端:客戶負責發送存儲項至伺服器端、從服務端擷取資料以及無法連接配接至伺服器時采用相應的動作;服務端負責接收、存儲資料,并負責資料項的逾時過期;
  3. 各伺服器間彼此無視:不在伺服器間進行資料同步;
  4. O(1)的執行效率
  5. 清理超期資料:預設情況下,Memcached是一個LRU緩存,同時,它按事先預訂的時長清理超期資料;但事實上,memcached不會删除任何已緩存資料,隻是在其過期之後不再為客戶所見;而且,memcached也不會真正按期限清理緩存,而僅是當get指令到達時檢查其時長;

Memcached内置操作指令

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

  • 存儲類指令:set, add, replace, append, prepend
  • 擷取資料類指令:get, delete, incr/decr
  • 統計類指令:stats, stats items, stats slabs, stats sizes
  • 清理指令: flush_all

一、安裝libevent

注意:memcached本身在用戶端連接配接的時候是使用事件驅動(event-driven),它利用的是libevent這個庫。(也就是說libevent這個庫可以提供event-driven(事件驅動)這樣的功能)

memcached依賴于libevent API,是以要事先安裝之,項目首頁:

http://libevent.org/

,讀者可自行選擇需要的版本下載下傳。本文采用的是目前最新版本的源碼包libevent-2.0.16-stable.tar.gz。安裝過程:

rpm -q libevent

//檢視一下是否已經安裝libevent庫

# 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認證,因為memcached預設不支援認證,是以私密資料會存在安全隐患,開啟sasl認證後,memcached可以借助sasl進行認證。在需要的時候可以開啟此選項
    // 但是開啟sasl之前要确認cyrus-sasl-devel的開發庫是否已經安裝,沒有的話,則安裝之;
    // rpm -qa | grep sasl
    // yum list all | grep sasl
    // yum install -y cyrus-sasl-devel
# make && make install
           

2、建立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"  #啟動失敗,去掉-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成為系統服務:
# chmod +x /etc/init.d/memcached
# chkconfig --add memcached
# chkconfig memcached on
# service memcached start
           

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

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

# 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

END

4、memcached啟動指令及常用選項說明

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

-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進行使用者認證;

-v: 顯示詳細資訊

-vv: 顯示更加詳盡的資訊

三、安裝Memcache的PHP擴充

1. 安裝PHP的memcache擴充

下載下傳位址:

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 
           

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

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

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

在“動态子產品”相關的位置添加如下一行來載入memcache擴充:

extension=/usr/local/php/lib/php/extensions/no-debug-non-zts-20090626/memcache.so

3. 測試php連接配接memcached

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

<?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已經能夠正常工作。

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

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

官方網站:

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網站根目錄下
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

進入登入界面,預設登入賬号密碼都是admin,如果想修改登入的賬号密碼,可修改如下配置檔案:

# 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;
        }
}