阿里云主机安装Memcached

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,详细参见阿里云服务器搭建LAMP环境

[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:* LISTEN
11211端口已经打开,说明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

[...]
memcache
mysql
mysqli
[...]

Memcache环境测试
新建一个test.php文件测试PHP的Memcache扩展效果,如果有输出This is a test!,就表示环境搭建成功。

<?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;
?>

 

使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了 试试是不是访问速度快了许多,这个效果对于访问量大的网站极为明显。

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。