Linux下的Memcache安装


给服务器配置环境,查了好多资料,终于安装成功。在此记录下安装过程,方便以后查阅。
Memcache是高性能,分布式的内存对象缓存系统,用于在动态应用中减少数据库负载,提升访问速度。据说官方所说,其用户包括twitter、digg、flickr等,都是些互联网大腕呀。目前用memcache解决互联网上的大用户读取是非常流行的一种用法。

1、下载Memcache和Libevent(说明:Memcache用到了libevent这个库用于Socket的处理,所以还需要安装libevent)
Memcache官方网站:http://memcached.org/
Libevent官方网站:http://monkey.org/~provos/libevent/
我这里下载的是memcached-1.4.17和libevent1.4.14

2,首先安装libevent1.4.14,解压压缩包,上传到临时目录,修改目录权限为777,安装。命令如下:
# chmod -R 777 libevent1.4.14
# cd libevent-1.4.14
# ./configure –prefix=/alidata/server/libevent1.4.14
# make
# make install

3.测试libevent是否安装成功:
ls -al /alidata/server/libevent1.4.14/lib
lrwxrwxrwx 1 root root 21 Mar 20 19:34 libevent-1.4.so.2 -> libevent-1.4.so.2.2.0
-rwxr-xr-x 1 root root 377851 Mar 20 19:34 libevent-1.4.so.2.2.0
-rw-r--r-- 1 root root 609954 Mar 20 19:34 libevent.a
lrwxrwxrwx 1 root root 26 Mar 20 19:34 libevent_core-1.4.so.2 -> libevent_core-1.4.so.2.2.0
-rwxr-xr-x 1 root root 139800 Mar 20 19:34 libevent_core-1.4.so.2.2.0
-rw-r--r-- 1 root root 233876 Mar 20 19:34 libevent_core.a
-rwxr-xr-x 1 root root 1014 Mar 20 19:34 libevent_core.la
lrwxrwxrwx 1 root root 26 Mar 20 19:34 libevent_core.so -> libevent_core-1.4.so.2.2.0
lrwxrwxrwx 1 root root 27 Mar 20 19:34 libevent_extra-1.4.so.2 -> libevent_extra-1.4.so.2.2.0
-rwxr-xr-x 1 root root 296954 Mar 20 19:34 libevent_extra-1.4.so.2.2.0
-rw-r--r-- 1 root root 470372 Mar 20 19:34 libevent_extra.a
-rwxr-xr-x 1 root root 1021 Mar 20 19:34 libevent_extra.la
lrwxrwxrwx 1 root root 27 Mar 20 19:34 libevent_extra.so -> libevent_extra-1.4.so.2.2.0
-rwxr-xr-x 1 root root 979 Mar 20 19:34 libevent.la
lrwxrwxrwx 1 root root 21 Mar 20 19:34 libevent.so -> libevent-1.4.so.2.2.0
还不错,都安装上了。

4.安装memcache,解压压缩包,上传到临时目录,修改目录权限为777,安装,安装时需要指定libevent的安装路径。命令如下:
# chmod -R 777 memcached-1.4.17
# cd memcached-1.4.17
# ./configure –prefix=/alidata/server/memcached-1.4.17 --with-libevent=/alidata/server/libevent1.4.14
# make
# make install

5.测试是否成功安装memcached:
# ls -al /alidata/server/memcached-1.4.17/bin/mem*
-rwxr-xr-x 1 root root 313395 Mar 20 19:42 /alidata/server/memcached-1.4.17/bin/memcached
不错,安装成功了

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

tar vxzf memcache-2.2.1.tgz
cd memcache-2.2.1
/usr/local/php/bin/phpize
./configure –enable-memcache –with-php-config=/usr/local/php/bin/php-config –with-zlib-dir
make
make install

3.上述安装完后会有类似这样的提示:

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

4.把php.ini中的extension_dir = “./”修改为

extension_dir = “/usr/local/php/lib/php/extensions/no-debug-non-zts-2007xxxx/”

5.添加一行来载入memcache扩展:extension=memcache.so

Memcached的基本设置:

1.启动Memcache的服务器端:
# /usr/local/bin/memcached -d -m 128 -u root -l 192.168.0.200 -p 12000 -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,service httpd 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;
?>

声明:麦子花开|版权所有,违者必究|如未注明,均为原创|本网站采用BY-NC-SA协议进行授权

转载:转载请注明原文链接 - Linux下的Memcache安装


休对故人思故国,且将新火试新茶。诗酒趁年华!