Linux企业实战-----openresty+nginx构建页面缓存

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)等来访问数据库再返回,这大大提高了应用的性能。

nginx本身具有高并发的特点,如果将数据缓存放在php后面,则客户请求发给nginx,nginx给php-fpm处理,然后将获取的数据缓存到memcache上,则nginx只有在等待php-fpm处理结束后,必定会影响数据传输速率,如果将memcache直接与nginx连接,当客户发出请求时,nginx直接从memcahce中将数据出给客户端,即可提高速率,这里我们使用openresty来实现。

在php+memcache模块中,即使memcahce命中,还是要进入memcahce生命周期,效率并不高,因此一种更高效的缓存策略是nginx直接访问memcache即使用openresty,并用uri和args等nginx内置变量设定缓存key规则,这样当命中缓存时,nginx可以跳过通过fastcgi和php通信过程,直接从memcache中获取数据并返回,提高效率。

 

openresty源码编译

tar zxf openresty-1.17.8.2.tar.gz
cd openresty-1.17.8.2/
./configure
gmake
gmake install
cd /usr/local/openresty/

 

openresty+nginx高速缓存实现

server3 server4:
yum install memcached -y
systemctl start memcached

 

server2:
vim /usr/local/openresty/nginx/conf/nginx.conf(增加后段server3、server4,开启php,增加缓存但不开启)
cp /usr/local/lnmp/nginx/html/memcache.php  ../html/
vim index.php
vim memcache.php(将监控地址改为server3 server4)
./nginx -t
./nginx -s reload
systemctl start php-fpm

# 将/memc设为internal表示只接受内部访问,不接收外部http请求,这是为了安全考虑,当然如果需要通过http协议开放外部访问,可以去掉internal然后使用deny和allow指令控制权限
memc_send_timeout 100ms;    ##后端服务器数据回传时间
memc_read_timeout 100ms;    ##连接成功后,后端服务器响应时间
这里为memc-nginx-module配置location,我们配置为/memc,所有请求都通过这个locaion来操作memcache,memc-nginx-module存取    
memcache是基于http method语义的,使http的GET方法表示get,PUT方法表示set,DELETE方法表示delete。internal表示只接受内部网络,不接受外部http请求,如果需要接受外部访问 ,可以使用allow和deny来指令控制权限。
$memc_key表示以什么key,这里直接使用nginx内置的$query_string来作为key,$memc_exptime表示缓存失效时间,以秒记,实际应用中根据具体情况设置。
memc_pass memcache;  #指向upstream模块

#用$uri和$args等Nginx内置变量设定缓存key规则
##~ \.php$这个location配置了缓存,这表示所有以.php结尾的请求结果都会被缓存。
#srcache_fetch_skip和srcache_fetch_skip,这两个指令接受一个参数,当参数已定义且非0时,则进行相应操作,否则不进行。
srcache_fetch表示注册一个输入拦截处理器到location,这个配置进入时将被执行;
而srcache_store表示注册一个输出拦截器到location,当location执行完成输出时会被执行。
完成以上配置后,相当于对nginx增加了这些逻辑:当所有请求以"'.php"结尾时,首先到memcahce中查询有没有以$url$args为key的数据,如果有则返回,否则执行location的逻辑。

 

home:
ab -c10 -n20000 http://172.25.11.2/index.php

server2:
vim /usr/local/openresty/nginx/conf/nginx.conf(开启缓存)

home
再次压测

未开启缓存压测结果:

开启缓存后,效果明显:

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值