给服务器配置环境,查了好多资料,终于安装成功。在此记录下安装过程,方便以后查阅。
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
Bash3.测试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
Bash还不错,都安装上了。
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
Bash5.测试是否成功安装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
Bash不错,安装成功了
安装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
Bash3.上述安装完后会有类似这样的提示:
Installing shared extensions: /usr/local/php/lib/php/extensions/no-debug-non-zts-2007xxxx/
Bash4.把php.ini中的extension_dir = “./”修改为
extension_dir = “/usr/local/php/lib/php/extensions/no-debug-non-zts-2007xxxx/”
Bash5.添加一行来载入memcache扩展:
extension=memcache.so
BashMemcached的基本设置:
1.启动Memcache的服务器端:
/usr/local/bin/memcached -d -m 128 -u root -l 192.168.0.200 -p 12000 -c 256 -P /tmp/memcached.pid
Bash- -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`
Bash也可以启动多个守护进程,不过端口不能重复。
3.重启apache
service httpd restart
BashMemcache环境测试:
运行下面的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;
?>
PHP