林中侠客

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等。简单的说就是将数据调用到内存中,然后从内存中读取,从而大大提高读取速度。

服务器端主要是安装memcache服务器端,目前的最新版本是memcached-1.3.0 。
下载:http://www.danga.com/memcached/dist/memcached-1.2.5.tar.gz
另外,Memcache用到了libevent这个库用于Socket的处理,所以还需要安装libevent,libevent的最新版本是libevent-1.3。

用wget指令直接下载这两个东西.下载回源文件后。
1.先安装libevent。这个东西在配置时需要指定一个安装路径,即./configure –prefix=/usr;然后make;然后make install;
2.再安装memcached,只是需要在配置时需要指定libevent的安装路径即./configure –with-libevent=/usr;然后make;然后make install;
这样就完成了Linux下Memcache服务器端的安装。详细的方法如下:
1.分别把memcached和libevent下载回来,放到 /usr/local/src目录下:
# cd /usr/local/src
# wget http://www.monkey.org/~provos/libevent-1.3.tar.gz

# wget http://www.danga.com/memcached/dist/memcached-1.2.5.tar.gz

 

2.先安装libevent:
# tar zxvf libevent-1.3.tar.gz
# cd libevent-1.3
# ./configure -prefix=/usr
# make
# make install

 

3.测试libevent是否安装成功:
# ls -al /usr/lib | grep libevent
lrwxrwxrwx   1 root root      22 Jan 24 01:38 libevent-1.1a.so.1 ->libevent-1.1a.so.1.0.2

-rwxr-xr-x   1 rootroot   31596 Jan  7  2007libevent-1.1a.so.1.0.2

lrwxrwxrwx   1 rootroot      21 Jan 24  2013 libevent-1.3.so.1 ->libevent-1.3.so.1.0.3

-rwxr-xr-x   1 rootroot  260076 Jan 24  2013 libevent-1.3.so.1.0.3

-rw-r--r--   1 rootroot  331144 Jan 24  2013 libevent.a

-rwxr-xr-x   1 rootroot     805 Jan 24  2013 libevent.la

lrwxrwxrwx   1 rootroot      21 Jan 24  2013 libevent.so -> libevent-1.3.so.1.0.3
还不错,都安装上了。

 

4.安装memcached,同时需要安装中指定libevent的安装位置:
# cd /usr/local/src
# tar zxvf memcached-1.2.5.tar.gz
# cd memcached-1.2.5
# ./configure -with-libevent=/usr
# make
# make install
如果中间出现报错,请仔细检查错误信息,按照错误信息来配置或者增加相应的库或者路径。
安装完成后会把memcached放到/usr/local/bin/memcached ,

 

5.测试是否成功安装memcached:
# ls -al /usr/local/bin/mem*
-rwxr-xr-x 1 root root 124281 Jan 24 2013 /usr/local/bin/memcached

-rwxr-xr-x 1 root root 132762 Jan 24  2013 /usr/local/bin/memcached-debug

 

安装Memcache的PHP扩展
1.在http://pecl.php.net/package/memcache选择相应想要下载的memcache版本。
2.安装PHP的memcache扩展

wget http://pecl.php.net/get/memcache-2.2.1.tgz

tar vxzf memcache-2.2.1.tgz
cd memcache-2.2.1
/usr/local/php/bin/phpize
./configure --with-php-config=/usr/local/php/bin/php-config

make
make install

 

memcached的基本设置:

1.启动Memcache的服务器端:
# /usr/local/bin/memcached -d -m 10 -u root -l 192.168.0.200 -p 11211 -c 256 -P/tmp/memcached.pid

-d选项是启动一个守护进程,
-m是分配给Memcache使用的内存数量,单位是MB,我这里是10MB,
-u是运行Memcache的用户,我这里是root,
-l是监听的服务器IP地址,如果有多个地址的话,我这里指定了服务器的IP地址192.168.0.200,
-p是设置Memcache监听的端口,我这里设置了12000,最好是1024以上的端口,
-c选项是最大运行的并发连接数,默认是1024,我这里设置了256,按照你服务器的负载量来设定,
-P是设置保存Memcache的pid文件,我这里是保存在 /tmp/memcached.pid,

 

2.如果要结束Memcache进程,执行:

# kill `cat /tmp/memcached.pid`

也可以启动多个守护进程,不过端口不能重复。

 

3.重启apache,servicehttpd restart

Memcache环境测试:
运行下面的php文件,如果有输出This is a test!,就表示环境搭建成功。开始领略Memcache的魅力把!
< ?php
$mem = new Memcache;
$mem->connect(”127.0.0.1″, 11211);
$mem->set(’key’, ‘This is a test!’, 0, 60);
$val = $mem->get(’key’);
echo $val;
?>

 

四、配置为自启动服务
1,编写memcached自启动脚本或直接使用memcached安装包中的脚本(位置如下,本文使用官方自带的脚本)
2,修改自启动脚本(红色部分标识,中文注释仅限本文提示用,安装包没有)

复制代码代码示例:

#! /bin/sh
#
# chkconfig: - 55 45
# description:  The memcached daemon is a network memory cache service.
# processname: memcached
# config: /etc/sysconfig/memcached

# Source function library - for other linux
#. /etc/rc.d/init.d/functions
# Source function library - for suse linux
. /lib/lsb/init-functions

PORT=11211
USER=root
#最大连接数,根据实际需求修改
MAXCONN=1024
#最大内存量,单位M
CACHESIZE=128
OPTIONS=""

if [ -f /etc/sysconfig/memcached ];then
. /etc/sysconfig/memcached
fi

# Check that networking is up.
if [ "$NETWORKING" = "no" ]
then
exit 0
fi

RETVAL=0
prog="memcached"

start () {
echo -n $"Starting $prog: "
# insure that /usr/local/memcached has proper permissions
chown $USER /usr/local/memcached
/usr/local/memcached/bin/memcached -d -p $PORT -u $USER  -m $CACHESIZE -c $MAXCONN -P /usr/local/memcached/memcached.pid $OPTIONS
RETVAL=$?
echo
[ $RETVAL -eq 0 ] && touch /var/lock/subsys/memcached
}
stop () {
echo -n $"Stopping $prog: "
killproc memcached
RETVAL=$?
echo
if [ $RETVAL -eq 0 ] ; then
rm -f /var/lock/subsys/memcached
rm -f /usr/local/memcached/memcached.pid
fi
}

restart () {
stop
start
}

# See how we were called.
case "$1" in
start)
start
;;
stop)
stop
;;
status)
status memcached
;;
restart|reload)
restart
;;
condrestart)
[ -f /var/lock/subsys/memcached ] && restart || :
;;
*)
echo $"Usage: $0 {start|stop|status|restart|reload|condrestart}"
exit 1
esac

exit $?

 shell > cp memcached.sysv /etc/init.d/memcached3.将此脚本cp到/etc/init.d目录下并改名为memcached,然后执行chmod a+x memcached,如下:

复制代码代码示例:
 shell > chmod 755 /etc/init.d/memcached

4,将memcached加入系统服务:

复制代码代码示例:
shell > chkconfig --add memcached
shell > chkconfig memcached on

5,以服务方式运行memcached

复制代码代码示例:
shell > service memcached start

以上如成功则重启下系统后查看下memcached是否已随系统启动。

posted on 2014-11-10 16:26  林中侠客  阅读(325)  评论(0编辑  收藏  举报