MemCache简介
Memcached是一个自由开源的,高性能,分布式内存对象缓存系统。
Memcached是以LiveJournal旗下Danga Interactive公司的Brad Fitzpatric为首开发的一款软件。现在已成为mixi、hatena、Facebook、Vox、LiveJournal等众多服务中提高Web应用扩展性的重要因素。
Memcached是一种基于内存的key-value存储,用来存储小块的任意数据(字符串、对象)。这些数据可以是数据库调用、API调用或者是页面渲染的结果。
Memcached简洁而强大。它的简洁设计便于快速开发,减轻开发难度,解决了大数据量缓存的很多问题。它的API兼容大部分流行的开发语言。
本质上,它是一个简洁的key-value存储系统。
一般的使用目的是,通过缓存数据库查询结果,减少数据库访问次数,以提高动态Web应用的速度、提高可扩展性。
内存缓存技术:MemCache是实现PHP语言 对内存 进行操作的中间介质
MemCache的工作流程如下:先检查客户端的请求数据是否在MemCached中,如有,直接把请求数据返回,不再对数据库进行任何操作;如果请求的数据不在MemCached中,就去查数据库,把从数据库中获取的数据返回给客户端,同时把数据缓存一份到 MemCached中(MemCached客户端不负责,需要程序明确实现);每次更新数据库的同时更新memcached中的数据,保证一致性;当分配给MemCached内存空间用完之后,会使用LRU(Least Recently Used,最近最少使用)策略加上到期失效策略,失效数据首先被替换,然后再替换掉最近未使用的数据。
1.为PHP添加环境变量
将前边PHP编译完成的二进制命令加入环境变量中,保证可以直接调用PHP命令
vim ~/.bash_profile
====================
# User specific environment and startup programs
PATH=$PATH:$HOME/bin
PATH=$PATH:$HOME/bin:/usr/local/lnmp/mysql/bin:/usr/local/lnmp/php/bin
=========================================================================
#使配置文件更改生效
source ~/.bash_profile
2.获取MemCache客户端压缩包,并解压
tar zxf memcache-2.2.5.tgz
3.进入解压目录,利用PHP制作configure文件
phpize是用来扩展php扩展模块的,通过phpize可以建立php的外挂模块,比如你想在原来编译好的php中加入memcached或者ImageMagick等扩展模块,可以使phpize。
或者说,phpize的作用可以这样理解:侦测环境(phpize工具是在php安装目录下,基于这点phpize对应了当时的php环境,所以是要根据该php的配置情况生成对应的configure文件),建立一个configure文件。必须在一个目录下去运行phpize。那么phpize就知道你的的环境是哪个目录,并且configure文件建立在该目录下。
cd memcache-2.2.5
phpize
4.配置
./configure
5.编译安装
make && make install
6.修改PHP配置文件,加载MemCache的动态模块
vim /usr/local/lnmp/php/etc/php.ini
====================================
873 extension=memcache.so
=====================================
#PHP重新加载配置文件
/etc/init.d/php-fpm reload
#察看是否成功加载模块
php -m | grep memcache
7.下载安装服务端软件
yum install -y memcached
8.开启MemCached服务
/etc/init.d/memcached start
#查看端口
netstat -antupe
9.复制example.php memcache.php到Nginx默认发布目录
cd memcache-2.2.5
cp example.php memcache.php /usr/local/lnmp/nginx/html/
10.修改memcache.php页面
cd /usr/local/lnmp/nginx/html/
vim memcache.php
======================
#修改登陆密码
23 define('ADMIN_PASSWORD','redhat'); // Admin Password
#修改服务器地址及端口
28 $MEMCACHE_SERVERS[] = 'localhost:11211'; // add more as an array
======================
#重新加载Nginx配置文件内容
nginx -s reload
11.测试
浏览器访问:http://172.25.70.1/example.php
浏览器访问:http://172.25.70.1/memcache.php
输入刚才配置的帐户、密码
这个就是统计界面,可以看到缓存使用率为100%
物理机进行压力测试
ab -c 10 -n 5000 http://172.25.70.1/index.php
ab是用来压力测试的 -c表示:让10台机器随时并发, -n:加起来发5000次
总用时:20.490 seconds
请求失败:511
ab -c 10 -n 5000 http://172.25.70.1/example.php
总用时:3.328 seconds
失败请求:0
命中缓存:100%