Nginx+php+memcached安裝配置

2017年2月4日16:16:35 發(fā)表評論 3,937 ℃

Memcached是一款開源、高性能、分布式內(nèi)存對象緩存系統(tǒng),可應(yīng)用各種需要緩存的場景,其主要目的是通過降低對Database的訪問來加速web應(yīng)用程序。它是一個基于內(nèi)存的“鍵值對”存儲,用于存儲數(shù)據(jù)庫調(diào)用、API調(diào)用或頁面引用結(jié)果的直接數(shù)據(jù),如字符串、對象等。

memcached是以LiveJournal旗下Danga Interactive 公司的Brad Fitzpatric 為首開發(fā)的一款軟件。現(xiàn)在

已成為mixi、hatena、Facebook、Vox、LiveJournal等眾多服務(wù)中提高Web應(yīng)用擴展性的重要因素。

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

1. 簡單key/value存儲:服務(wù)器不關(guān)心數(shù)據(jù)本身的意義及結(jié)構(gòu),只要是可序列化數(shù)據(jù)即可。存儲項由“鍵、過期時間、可選的標志及數(shù)據(jù)”四個部分組成;

2. 功能的實現(xiàn)一半依賴于客戶端,一半基于服務(wù)器端:客戶負責發(fā)送存儲項至服務(wù)器端、從服務(wù)端獲取數(shù)據(jù)以及無法連接至服務(wù)器時采用相應(yīng)的動作;服務(wù)端負責接收、存儲數(shù)據(jù),并負責數(shù)據(jù)項的超時過期;

3. 各服務(wù)器間彼此無視:不在服務(wù)器間進行數(shù)據(jù)同步;

4. O(1)的執(zhí)行效率

5. 清理超期數(shù)據(jù):默認情況下,Memcached是一個LRU緩存,同時,它按事先預(yù)訂的時長清理超期數(shù)據(jù);但事實上,memcached不會刪除任何已緩存數(shù)據(jù),只是在其過期之后不再為客戶所見;而且,memcached也不會真正按期限清理緩存,而僅是當get命令到達時檢查其時長;

Memcached提供了為數(shù)不多的幾個命令來完成與服務(wù)器端的交互,這些命令基于memcached的協(xié)議實現(xiàn)。

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

獲取數(shù)據(jù)類命令:get, delete, incr/decr

統(tǒng)計類命令:stats, stats items, stats slabs, stats sizes

清理命令: flush_all

一、安裝libevent

memcached依賴于libevent API,因此要事先安裝之,項目主頁: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

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

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=""

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 -o "$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命令測試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的常用選項說明

-l <ip_addr>:指定進程監(jiān)聽的地址;

-d: 以服務(wù)模式運行;

-u <username>:以指定的用戶身份運行memcached進程;

-m <num>:用于緩存數(shù)據(jù)的最大內(nèi)存空間,單位為MB,默認為64MB;

-c <num>:最大支持的并發(fā)連接數(shù),默認為1024;

-p <num>: 指定監(jiān)聽的TCP端口,默認為11211;

-U <num>:指定監(jiān)聽的UDP端口,默認為11211,0表示關(guān)閉UDP端口;

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

-f <num>:設(shè)定Slab Allocator定義預(yù)先分配內(nèi)存空間大小固定的塊時使用的增長因子;

-M:當內(nèi)存空間不夠使用時返回錯誤信息,而不是按LRU算法利用空間;

-n: 指定最小的slab chunk大??;單位是字節(jié);

-S: 啟用sasl進行用戶認證;

三、安裝Memcache的PHP擴展

①安裝PHP的memcache擴展

# 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

# make && make install

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

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

②編輯/usr/local/php/lib/php.ini,在“動態(tài)模塊”相關(guān)的位置添加如下一行來載入memcache擴展:

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

而后對memcached功能進行測試,在網(wǎng)站目錄中建立測試頁面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.";        

?>

如果有輸出“Hello World is from memcached.”等信息,則表明memcache已經(jīng)能夠正常工作。

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

訪問memcached的傳統(tǒng)方法是使用基于perl語言開發(fā)的Cache::memcached模塊,這個模塊在大多數(shù)perl代碼中都能良好的工作,但也有著眾所周知的性能方面的問題。libMemcached則是基于C語言開發(fā)的開源的C/C++代碼訪問memcached的庫文件,同時,它還提供了數(shù)個可以遠程使用的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

五、Nginx整合memcached:

server {

        listen       80;

        server_name  www.zhongjima.net;

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

        }

}

【騰訊云】云服務(wù)器、云數(shù)據(jù)庫、COS、CDN、短信等云產(chǎn)品特惠熱賣中

發(fā)表評論

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: