http://www.zyuns.com/?page_id=354
前言
最近发现阿里云主机在使用中,并发访问量稍大,页面加载速度就很慢。于是学习了一些服务器优化的文章,决定安装Memcached,优化页面查询,提高Wordpress的响应速度。这里记录下阿里云主机Centos6.3的Memcached安装的过程。Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提供动态、数据 库驱动网站的速度。Memcached基于一个存储键/值对的hashmap。其守护进程(daemon)是用C写的,但是客户端可以用任何语言来编写, 并通过memcached协议与守护进程通信。但是它并不提供冗余(例如,复制其hashmap条目);当某个服务器停止运行或崩溃了,所有存放在该服务 器上的键/值对都将丢失。
Memcached函数库是在PECL(PHP Extension Community Library)中,主要作用是搭建大容量的内存数据的临时存放区域,在分布式环境下的作用体现的非常明显。
本文就详细讲解如何让PHP支持Memcached,以提高大访问量网站的访问速度,本文的PHP和Memcached的安装环境为Centos6.3操作系统。
安装Memcached前的准备工作
(1)首先安装apache、mysql、php,详细参见
[root@Linux ~]#yum install -y httpd-* mysql-server mysql mysql-devel php-*
(2)安装libevent libevent-devel
Memcached需要libevent的支持,详细的内容可以找下关于memcached的原理。[root@Linux ~]#yum install -y libevent libevent-devel
(3)安装php-devel gcc make
Memcached编译时需要用到php-devel gcc make,需事先安装好[root@Linux ~]#yum install -y php-devel gcc make
安装memcached
方法一:yum安装简单方便
[root@Linux ~]#yum -y install memcached
方法二:下载安装
到http://memcached.org/下载最新版本的memcached源代码包[root@Linux ~]#wget http://memcached.googlecode.com/files/memcached-1.4.13.tar.gz
然后就可以就如安装步骤了
[root@Linux ~]#tar zxvf memcached-1.4.13.tar.gz[root@Linux ~]#cd memcached-1.4.13[root@Linux ~]#./configure --prefix=/usr/local/memcached[root@Linux ~]#make[root@Linux ~]#make install[root@Linux ~]#ln -s /usr/local/memcached/bin/memcached /usr/local/bin/
启动memcached
[root@Linux ~]#memcached -d -m 10 -u root -l 127.0.0.1 -p 11211 -c 256 -P /tmp/memcached
参数说明:
-d选项是启动一个守护进程,-m是分配给Memcached使用的内存数量,单位是MB,这里是10MB,-u是运行Memcached的用户,我这里是root,-l是监听的服务器IP地址,如果有多个地址的话,由于是本地开发( 非实际运行环境 )这里指定了服务器的IP地址127.0.0.1,-p是设置Memcached监听的端口,这里设置了11211,最好是1024以上的端口,-c选项是最大运行的并发连接数,默认是1024,这里设置了256,按照服务器的负载量来设定,-P是设置保存Memcached的pid文件,这里是保存在 /tmp/memcached.pid。验证安装
memcached -h应该会输出一些帮助信息将memcached加入启动列表
chkconfig –level 2345 memcached on配置Memcached
vi /etc/sysconfig/memcached文件中内容如下PORT=”11211″ 端口USER=”root” 使用的用户名MAXCONN=”1024″ 同时最大连接数CACHESIZE=”64″ 使用的内存大小OPTIONS=”” 附加参数查看memcached状态
memcached-tool [Memcached Server IP]:[Memcached Server Port] stats如:memcached-tool 127.0.0.1:11211 stats检查Memcached是否启动
netstat -ant出现类似这样的结果 tcp 0 0 88.88.88.88:11211 0.0.0.0:* LISTEN11211端口已经打开,说明Memcached已正常启动。=====至此,我们将Memcached服务配置完毕,接着我们配置PHP的扩展,以便在程序中来调用=====
安装Memcached的php扩展
PHP有两种Memcached扩展,老一点的叫memcache,新一点的叫memcached,这里我安装的是memcache。
首先到http://pecl.php.net/package/memcache下载memcached的php扩展最新稳定版本[root@Linux ~]#wget http://pecl.php.net/get/memcache-2.2.5.tgz
解压:
[root@Linux ~]#tar zxvf memcache-2.2.5.tgz
编译安装:
[root@Linux ~]#cd memcache-2.2.5[root@Linux ~]#phpize[root@Linux ~]#./configure --enable-memcache --with-php-config=/usr/bin/php-config --with-zlib-dir[root@Linux ~]#make[root@Linux ~]#make install
安装成功后提示:”Installing shared extensions: /usr/lib64/php/modules/”。
在php.ini文件中添加memcache扩展
[root@Linux ~]#vim /etc/php.ini
添加以下内容
extension_dir = "/usr/lib64/php/modules/"extension=memcache.so
检验Memcache安装
[root@Linux ~]#php -m[...]memcachemysqlmysqli[...]
Memcache环境测试
新建一个test.php文件测试PHP的Memcache扩展效果,如果有输出This is a test!,就表示环境搭建成功。connect("127.0.0.1", 11211);$mem->set('key', 'This is a test!', 0, 60);$val = $mem->get('key');echo $val;?>
使Wordpress支持memcached
首先在 http://plugins.trac.wordpress.org/browser/memcached/trunk 目录下载object-cache.php的最新版本,将该文件放在wordpress目录中的wp-content 文件夹内。
一般的说法就是这样子就算启动了 wordpress 的 memcache 插件了,如果没有启动,需要修改这个文件的内容。
确认memcached进程使用的端口,默认的端口是11211,如果你守候了其他的进程(例如:14141),那么需要你在wp-config.php文件中增加如下代码:
global $memcached_servers;$memcached_servers = array(’default’ => array(’127.0.0.1:14141′));//这里的14141替换为你设置的端口
这样配置以后 应该就可以支持memcached了 试试是不是访问速度快了许多,这个效果对于访问量大的网站极为明显。