一、MemCache基础概念
Memcached是一个自由开源的,高性能,分布式内存对象缓存系统。
Memcached是以LiveJournal旗下Danga Interactive公司的BradFitzpatric为首开发的一款软件。现在已成为mixi、hatena、Facebook、Vox、LiveJournal等众多服务中提高Web应用扩展性的重要因素。
Memcached是一种基于内存的key-value存储,用来存储小块的任意数据(字符串、对象)。这些数据可以是数据库调用、API调用或者是页面渲染的结果。
Memcached简洁而强大。它的简洁设计便于快速开发,减轻开发难度,解决了大数据量缓存的很多问题。它的API兼容大部分流行的开发语言。
本质上,它是一个简洁的key-value存储系统。
一般的使用目的是,通过缓存数据库查询结果,减少数据库访问次数,以提高动态Web应用的速度、提高可扩展性。
- memcache是一个高性能的分布式的内存对象缓存系统,用于动态Web应用以减轻数据库负担。
- memcache通过在内存里维护一个统一的巨大的hash表,来存储经常被读写的一些数组与文件,从而极大的提高网站的运行效率。
- memcache是一种内存缓存技术,是一种缓存手段,要看情况来使用。
memcache使用场景
-
访问频繁的字典数据
-
大量的hot数据
-
页面缓存
-
频繁的查询条件和结果
-
临时处理的数据
Memcache和memcached的区别
Memcache是这个项目的名称
而memcached是它服务器端的主程序文件名。
二、Memcache对PHP页面的缓存加速优化,配置过程详解
搭建步骤:
1.获得软件包资源,解压
[root@server1 ~]# tar zxf memcache-2.2.5.tgz
2.设定环境变量,创建编译环境,将前边php编译完成的二进制命令加入环境变量中,保证可以直接调用php命令
[root@server1 memcache-2.2.5]# vim ~/.bash_profile
10 PATH=$PATH:$HOME/bin:/usr/local/lnmp/mysql/bin:/usr/local/lnmp/php/bin
[root@server1 memcache-2.2.5]# source ~/.bash_profile
[root@server1 memcache-2.2.5]# phpize #可以用来试探当前的环境,从而生成./configure
Configuring for:
PHP Api Version: 20131106
Zend Module Api No: 20131226
Zend Extension Api No: 220131226
[root@server1 memcache-2.2.5]# ls #可以看见有./configure编译环境存在
3.创建一个预编译环境并进行编译汇编memcache源码包
- phpize是用来扩展php扩展模块的,通过phpize可以建立php的外挂模块,比如你想在原来编译好的php中加入memcached或者ImageMagick等扩展模块,可以使用phpize。
- phpize工具是在php安装目录下,基于这点phpize对应了当时的php环境,所以是要根据该php的配置情况生成对应的configure文件,建立一个configure文件。必须在一个目录下去运行phpize,那么phpize就知道你的的环境是哪个目录,并且configure文件建立在该目录下。
[root@server1 memcache-2.2.5]# ./configure #会生成config.h文件 # 源码编译,已经安装好了php,我们就不用再指定新的php扩展模块路径
[root@server1 memcache-2.2.5]# make && make install
注意:会生成/usr/local/lnmp/php/lib/php/extensions/no-debug-non-zts-20131226/目录
4.修改php配置文件(让php和memcache建立连接)
[root@server1 memcache-2.2.5]# vim /usr/local/lnmp/php/etc/php.ini
873 extension=memcache.so #注释打开
[root@server1 memcache-2.2.5]# /etc/init.d/php-fpm reload
Reload service php-fpm done
[root@server1 etc]# php -m ##查看php模块
[root@server1 etc]# php -m | grep memcache ##过滤memcache模块,发现已经有了这个模块
memcache
[root@server1 etc]# php -m | grep mysql ##同时支持mysql
mysql
mysqli
mysqlnd
pdo_mysql
5.安装memcache工具
[root@server1 etc]# yum install -y memcached
[root@server1 memcache-2.2.5]# cat /etc/sysconfig/memcached #可以查看他的监控信息
PORT="11211"
USER="memcached"
MAXCONN="1024"
CACHESIZE="64"
OPTIONS=""
[root@server1 etc]# /etc/init.d/memcached start
[root@server1 etc]# netstat -tnlp ##查看监听端口(11211端口)
8.安装telnet工具(让可以访问本机的11211)
[root@server1 memcache-2.2.5]# yum install telnet -y
[root@server1 memcache-2.2.5]# telnet localhost 11211
stats #查看状态
set name 0 0 6 #设置key-value存储 KEY值, 序号 缓存时间 VALUE值长度
westos
get name #查看
9.将memcache的发布页复制到nginx的发布目录下
[root@server1 memcache-2.2.5]# cp memcache.php example.php /usr/local/lnmp/nginx/html/
[root@server1 memcache-2.2.5]# cd /usr/local/lnmp/nginx/html/
[root@server1 html]# vim memcache.php
22 define('ADMIN_USERNAME','memcache'); ##用户为memcache
23 define('ADMIN_PASSWORD','westos'); ##设置密码为westos // Admin Password
28 $MEMCACHE_SERVERS[] = '172.25.254.1:11211'; // add more as an array
29 #$MEMCACHE_SERVERS[] = 'mymemcache-server2:11211'; // add more as an array
10.测试:
浏览器输入:172.25.254.1/memcache.php
然后重新打开一个浏览器页面,输入172.2.79.1:example.php ,不断刷新
当访问多次example.php后,查看命中情况会不断提高,最后将会达到百分之百。
9.压力测试:加速页面exmple.php和没加速index。php的对比(错误率对比,相应时间对比)
(1)访问index.php
[root@server1 ~]# ab -c 10 -n 5000 http://172.25.79.1/index.php #-c表示:让10台机器随时并发, -n:加起来发5000次
可以看到所用时间为5s左右,出错个数为518个
(2)访问example.php
[root@server1 ~]# ab -c 10 -n 5000 http://172.25.79.1/example.php
可以看到所用时间为2s左右,出错个数为0个,速度提高了,错误率大大降低