linux memcache安裝配置方法
投稿:mdxy-dxy
基本原理:
① 客戶端第一次訪問應(yīng)用程序時(shí),會(huì)到數(shù)據(jù)庫(RDBMS)中取出數(shù)據(jù),返回給客戶端;同時(shí)也將取出的數(shù)據(jù)保存到memcached中。
② 第二次訪問時(shí),因?yàn)閿?shù)據(jù)已經(jīng)緩存,就不用去數(shù)據(jù)庫查詢了,直接從memcached中取。
RDBMS是文件型的數(shù)據(jù)庫,最終還是以文件的形式保存在磁盤上;而memcached則不一樣,它是key:value關(guān)系型的數(shù)據(jù)庫,是保存在內(nèi)存中的。內(nèi)存的讀寫速度要比磁盤的讀寫速度快得多,前者是后者的10的6次方倍。
memcached是基于libevent的事件處理。libevent是個(gè)程序庫,它將Linux的epoll、BSD類操作系統(tǒng)的kqueue等事件處理功能封裝成統(tǒng)一的接口。即使對(duì)服務(wù)器的連接數(shù)增加,也能發(fā)揮O(1)的性能。 memcached使用這個(gè)libevent庫,因此能在Linux、BSD、Solaris等操作系統(tǒng)上發(fā)揮其高性能。關(guān)于事件處理這里就不再詳細(xì)介紹,可以參考Dan Kegel的The C10K Problem。欲了解更多關(guān)于libevent:http://monkey.org/~provos/libevent/ 。
編譯安裝Memcached
1、由于memcached是基于libevent的,因此需要安裝libevent,libevent-devel
# yum install libevent libevent-devel -y
2、下載并解壓memcached-1.4.6.tar.gz
memcached官方網(wǎng)站是:http://memcached.org/
# tar -xvzf memcached-1.4.6.tar.gz
3、編譯安裝memcached-1.4.6
# cd memcached-1.4.6
# ./configure --prefix=/etc/memcached
# make
# make install
4、配置環(huán)境變量(這一步可忽略...)
進(jìn)入用戶宿主目錄,編輯.bash_profile,為系統(tǒng)環(huán)境變量LD_LIBRARY_PATH增加新的目錄,需要增加的內(nèi)容如下:
# vi .bash_profile
MEMCACHED_HOME=/etc/memcached
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$MEMCACHED_HOME/lib
刷新用戶環(huán)境變量:# source .bash_profile
5、編寫memcached服務(wù)啟停腳本
# cd /etc/init.d
vi memcached,腳本內(nèi)容如下:
#!/bin/sh # # Startup script for the server of memcached # # processname: memcached # pidfile: /etc/memcached/memcached.pid # logfile: /etc/memcached/memcached_log.txt # memcached_home: /etc/memcached # chkconfig: 35 21 79 # description: Start and stop memcached Service # Source function library . /etc/rc.d/init.d/functions RETVAL=0 prog="memcached" basedir=/etc/memcached cmd=${basedir}/bin/memcached pidfile="$basedir/${prog}.pid" #logfile="$basedir/memcached_log.txt" ipaddr="192.168.1.200" # 綁定偵聽的IP地址 port="11211" # 服務(wù)端口 username="root" # 運(yùn)行程序的用戶身份 max_memory=64 # default: 64M | 最大使用內(nèi)存 max_simul_conn=1024 # default: 1024 | 最大同時(shí)連接數(shù) #maxcon=51200 #growth_factor=1.3 # default: 1.25 | 塊大小增長(zhǎng)因子 #thread_num=6 # default: 4 #verbose="-vv" # 查看詳細(xì)啟動(dòng)信息 #bind_protocol=binary # ascii, binary, or auto (default) start() { echo -n $"Starting service: $prog" $cmd -d -m $max_memory -u $username -l $ipaddr -p $port -c $max_simul_conn -P $pidfile RETVAL=$? echo [ $RETVAL -eq 0 ] && touch /var/lock/subsys/$prog } stop() { echo -n $"Stopping service: $prog " run_user=`whoami` pidlist=`ps -ef | grep $run_user | grep memcached | grep -v grep | awk '{print($2)}'` for pid in $pidlist do # echo "pid=$pid" kill -9 $pid if [ $? -ne 0 ]; then return 1 fi done RETVAL=$? echo [ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/$prog } # See how we were called. case "$1" in start) start ;; stop) stop ;; #reload) # reload # ;; restart) stop start ;; #condrestart) # if [ -f /var/lock/subsys/$prog ]; then # stop # start # fi # ;; status) status memcached ;; *) echo "Usage: $0 {start|stop|restart|status}" exit 1 esac exit $RETVAL
6、賦予執(zhí)行權(quán)限
#chmod +x memcached
7、設(shè)置memcached隨系統(tǒng)啟動(dòng)
# chkconfig --add memcached
# chkconfig --level 35 memcached on
啟動(dòng)memcached
# service memcached start
//啟動(dòng)的時(shí)候?qū)嶋H上是調(diào)用了下面的這個(gè)命令,以守護(hù)進(jìn)程的方式來啟動(dòng)memcached
/etc/memcached/bin/memcached -d -m 64 -u root -l 192.168.1.201 \
-p 11211 -c 1024 -P /etc/memcached/memcached.pid
查看memcached是否啟動(dòng)
# ps -ef | grep memcached
安裝Memcache的PHP擴(kuò)展
1.在http://pecl.php.net/package/memcache 選擇相應(yīng)想要下載的memcache版本。
2.安裝PHP的memcache擴(kuò)展
tar vxzf memcache-2.2.5.tgz
cd memcache-2.2.5
/usr/local/php/bin/phpize
./configure --enable-memcache --with-php-config=/usr/local/php/bin/php-config --with-zlib-dir
make
make install
3.上述安裝完后會(huì)有類似這樣的提示:
Installing shared extensions: /usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/
4.把php.ini中的extension_dir = “./”修改為
extension_dir = “/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/”
5.添加一行來載入memcache擴(kuò)展:extension=memcache.so
接下來重啟php就可以了,可以通過phpinfo測(cè)試頁面查看