PHP扩展memcache缓存模块
1)将phpize加入环境变量
将php的bin目录路径增加到 ~/.bash_profile中,为了方便调用
PATH=$PATH:$HOME/bin:/usr/local/lnmp/mysql/bin:/usr/local/lnmp/php/bin
source ~/.bash_profile
2)解包 tar zxf memcache-2.2.5.tgz
memcache目录中本来没有configure文件,所以没法编译
yum install autoconf -y
先执行命令:phpize
#########################################################################
phpize是用来扩展php扩展模块的,通过phpize可以建立php的外挂模块,比如你想在原来编译好的php中加入memcached或者ImageMagick等扩展模块,可以使用phpize。或者说,phpize的作用可以这样理解:侦测环境(phpize工具是在php安装目录下,基于这点phpize对应了当时的php环境,所以是要根据该php的配置情况生成对应的configure文件),建立一个configure文件。必须在一个目录下去运行phpize。那么phpize就知道你的的环境是哪个目录,并且configure文件建立在该目录下
#########################################################################
会生成configure文件
3)编译安装memcache
##编译
./configure
##安装
make && make install
4)修改php主配置文件,增加memcache模块
vim /usr/local/lnmp/php/etc/php.ini
873 extension=memcache.so
5)重新加载php
/etc/init.d/php-fpm reload
6)
php -m | grep memcache 可以查看是否加载成功
php -m | grep mysql
7)安装memcached
yum install -y memcached
8)查看memcached的配置文件
[root@server1 sbin]# cat /etc/sysconfig/memcached
PORT="11211"
USER="memcached"
MAXCONN="1024" ##最大链接数1024
CACHESIZE="64"
OPTIONS="" (如果写为OPTIONS="-l 127.0.0.1" 即为只监听本机的11211端口)
9)启动memcached
/etc/init.d/memcached start
rhel 7 版本:systemctl start memcached
10)telnet测试 ##没有的话:yum install -y telnet
telnet localhost 11211
stats(查看状态)
set name 0 0 6 (0编号 0缓存时间(此处0代表不限制时间) 6限制字符数) key:name;编号:0;缓存时间:0(永久)valuce值:6位
westosawd
CLIENT_ERROR bad data chunk
ERROR
westos
STORED
get name
VALUE name 0 6
westos
END
delete name
DELETED
set name 0 5 6 ##设置缓存5s,过5s再获取name,为空
westos
STORED
get name
END
quit #退出
11)拷贝php页面到nginx默认发布目录
memcache.php监控页面;example.php测memcache命中率
[root@server1 memcache-2.2.5]# cp memcache.php example.php /usr/local/lnmp/nginx/html/
修改内容
define('ADMIN_USERNAME','memcache'); ## Admin Username(自定义)
define('ADMIN_PASSWORD','redhat'); ## Admin Password(自定义)
$MEMCACHE_SERVERS[] = '172.25.230.5:11211'; // add more as an array
#$MEMCACHE_SERVERS[] = 'mymemcache-server2:11211'; // add more as an array
只留一个主机,memcache没有转发或负载均衡机制,只能一个一个添加(因为本实验只有一个主机,其实可以添加多个)
12)访问http://172.25.40.1/memcache.php
输入用户名密码,可以查看memcache命中率,使用http://172.25.40.1/example.php不停刷新来测试
13)在物理机上分别对两个页面进行压测
[root@localhost ~]# ab -c 10 -n 5000 http://172.25.40.1/index.php #很慢,因为没有缓存,而且failed比较多 10个并发,5000个请求
[root@localhost ~]# ab -c 10 -n 5000 http://172.25.40.1/example.php #很快,因为访问缓存,而且没有failed的
观察时间和命中率
OpenResty(nginx)扩展memcache缓存模块
缓存前移openresty
openresty是更强大的nginx,原生装有更多的模块,比如在nginx后加memcache所需要的memc-nginx和srcache-nginx模块,可以直接用openresty完成,而不需要重新编译,nginx本身不支持动态编译。
传统上,PHP中使用memcache的方法是使用php-memcache或php-memached扩展操作Memcache。
传统上是通过PHP操作memcache的,要执行PHP代码,Nginx就必然要和FastCGI通信,同时也要进入PHP的生命周期,因此SAPI、PHP Core和Zend Engine的一系列逻辑会被执行。更糟糕的是,fpm和PHP可能会阻塞,因此破坏了Nginx的非阻塞性。
因此一种更高效的缓存策略是Nginx直接访问Memcache,并用uri和args等Nginx内置变量设定缓存key规则。
其中,memc模块扩展了Nginx标准的memcache模块,增加了set、add、delete等memcache命令,而srcache则是为location增加了透明的基于subrequest的缓存层。
1.什么是OpenResty?
OpenResty(又称:ngx_openresty) 是一个基于 NGINX 的可伸缩的 Web平台,由中国人章亦春发起,提供了很多高质量的第三方模块。
OpenResty 是一个强大的 Web 应用服务器,Web 开发人员可以使用 Lua 脚本语言调动 Nginx 支持的各种 C 以及Lua 模块,更主要的是在性能方面,OpenResty可以 快速构造出足以胜任 10K 以上并发连接响应的超高性能 Web 应用系统。
360,UPYUN,阿里云,新浪,腾讯网,去哪儿网,酷狗音乐等都是 OpenResty 的深度用户。
OpenResty 的目标是让你的 Web 服务直接跑在 Nginx 服务内部,充分利用 Nginx 的非阻塞 I/O 模型,不仅仅对 HTTP 客户端请求,甚至于对远程后端诸如 MySQL,PostgreSQL,~Memcaches 以及 ~Redis 等都进行一致的高性能响应。
所以对于一些高性能的服务来说,可以直接使用 OpenResty 访问 Mysql或Redis等,而不需要通过第三方语言(PHP、Python、Ruby)等来访问数据库再返回,这大大提高了应用的性能。
参考openresty中文官网 http://openresty.org/cn/
~~
原nginx不支持memcache
1)给nginx添加memc和srcache模块,让nginx直接访问memcache来提高速度
先关闭原来的nginx,因为下面安装的openresty-1.13.6.1.tar.gz也是nginx
nginx -s stop
源码编译安装openresty-1.13.6.1.tar.gz(不需要加参数,使用默认)
tar zxf openresty-1.13.6.1.tar.gz
cd openresty-1.13.6.1
./configure --prefix=/usr/local/openresty
gmake && gmake install
拷贝之前example.php和index.php到默认发布目录准备测试
/usr/local/openresty/nginx/html
[root@server1 html]# cp /usr/local/lnmp/nginx/html/index.php .
[root@server1 html]# cp /usr/local/lnmp/nginx/html/example.php .
修改nginx配置文件:vim /usr/local/openresty/nginx/conf/nginx.conf
添加:
upstream memcache {
server localhost:11211;
keepalive 512;
}
location /memc {
internal; # 只接收内部访问,不接受外部http访问。比较安全
memc_connect_timeout 100ms;
memc_send_timeout 100ms; ##后端服务器数据回传时间
memc_read_timeout 100ms; ##连接成功后,后端服务器响应时间
set $memc_key $query_string;
set $memc_exptime 300;
memc_pass memcache;
}
location ~ \.php$ {
set $key $uri$args;
##http的GET方法表示get、PUT方法表示set
srcache_fetch GET /memc $key;(这两个配置的作用是:请求php页面时,先会去memcache中找,如果没有,正常访问;
srcache_store PUT /memc $key; 访问结束后将结果存到memcache,下次访问时直接从缓存中)
root html;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
#fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
include fastcgi.conf;
}
[root@server1 conf]# /usr/local/lnmp/openresty/nginx/sbin/nginx -t
[root@server1 conf]# /usr/local/lnmp/openresty/nginx/sbin/nginx
再次进行压测,速度会比之前只加了php的缓存更快
[root@foundation40 Desktop]# ab -c 10 -n 5000 http://172.25.40.1/example.php