LNMP架构—OpenResty实现缓存前移(到达nginx层面)


文章目录

  • LNMP架构---OpenResty实现缓存前移(到达nginx层面)
  • 1.什么是OpenResty?
  • 2.缓存前移的实现


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访问Mysq|或Redis等,而不需要通过第三方语言( PHP、Python、Ruby )等来访问数据库再返回,这大大提高了应用的性能。

参考openresty中文官网http://openresty.org/cn

2.缓存前移的实现

step1 解压并源码编译openresty源码包:

tar zxf openresty-1.13.6.1.tar.gz 
cd openresty-1.13.6.1
./configure --prefix=/usr/local/openresty
gmake && gmake install

step2 修改openresty的配置文件:

cd /usr/local/openresty/
cd nginx/
cd conf/
nginx -s stop	#关闭之前的nginx服务
vim nginx.conf

  1 
  2 user  nginx nginx;

 17 http {
 18     include       mime.types;
 19     default_type  application/octet-stream;
 20         upstream memcache {
 21                 server localhost:11211;
 22                 keepalive 512;
 23 }

 69         location /memc {
 70                 internal;       #只接收内部访问,不接受外部http访问。比较安全
 71                 memc_connect_timeout 100ms;
 72                 memc_send_timeout 100ms;        #后端服务器数据回传时间
 73                 memc_read_timeout 100ms;        #连接成功后,后端服务器响应时间
 74                 set $memc_key $query_string;
 75                 set $memc_exptime 300;
 76                 memc_pass memcache;
 77         }
 78 
 79         location ~ \.php$ {
 #http的GET方法表示get、PUT方法表示set
 80             set $key $uri$args;
 81             srcache_fetch GET /memc $key;		#请求php页面时,会先去memcache中找。如果没有,正常访问;
 82             srcache_store PUT /memc $key;		#访问结束后将结果存到memcache中,下次访问时直接从缓存中取
 83             root           html;
 84             fastcgi_pass   127.0.0.1:9000;
 85             fastcgi_index  index.php;
 86         #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
 87             include        fastcgi.conf;
 88         }

OpenResty模板 openresty架构_nginx


OpenResty模板 openresty架构_缓存_02


OpenResty模板 openresty架构_php_03

OpenResty模板 openresty架构_nginx_04


step3 将测试文件复制到openresty的默认发布目录下:

cp /usr/local/lnmp/nginx/html/index.php /usr/local/openresty/nginx/html/
cp /usr/local/lnmp/nginx/html/example.php /usr/local/openresty/nginx/html/

step4 启动openstry:

/usr/local/openresty/nginx/sbin/nginx

OpenResty模板 openresty架构_OpenResty模板_05


step5 测试:

ab -c 10 -n 5000 http://172.25.254.1/index.php
ab -c 10 -n 5000 http://172.25.254.1/example.php

OpenResty模板 openresty架构_php_06


OpenResty模板 openresty架构_nginx_07


通过测试可以发现:相比上一篇博文中的一层缓存,再加一层缓存后,速度大大提高,且出错率为0