nginx中lua进行时间比较_nginx高性能web服务器详解


简介

OpenResty是一款基于Nginx的高性能负载均衡服务器容器,简单来说是Nginx+Lua。结合了Lua语言来对Nginx进行扩展,使得在Nginx上具有web容器功能。

使得可以使用lua脚本来进行web的开发。有了lua,我们可以借助于nginx的异步非阻塞的功能,达到使用 lua 异步并发访问后端的 MySQL, Memcached, Redis等等服务。

OpenResty 架构的web可以轻松超越Node.js的性能,并且对后端语言没有限制,你可以使用Java/PHP/Python等等各种语言。OpenResty(nginx+lua)可以替代node.js的前端渲染的功能。

电商网站使用场景

电商网站pcwap首页及商品详情页生成静态页后,存储Redis上,然后通过OpenResty(nginx+lua脚本)从Redis读取静态页,前端渲染,展示给用户。提升页面访问速度及高并发。

OpenResty运行环境搭建

这里采用docker方式安装

拉取镜像

docker pull openresty/openresty:1.15.8.2-7-centos

启动openresty

端口映射为 8081,映射配置目录便于修改配置

docker run --rm -d --name openresty -p 8081:80 -v /opt/deploy-script/openresty/:/usr/local/openresty/nginx/conf/ openresty/openresty:1.15.8.2-7-centos

编写lua脚本

在/opt/deploy-script/openresty/lua 目录下 新建.lua 文件,并添加如下内容

local request_uri = ngx.var.uri local redis = require "resty.redis"local red = redis:new()--red:set_timeout(10000) -- 1 seclocal ok, err = red:connect("实际ip", 6379)if not ok then    ngx.say("failed to connect: ", err)    returnend--如果设置了密码请打开注释,并填写密码local res, err = red:auth("实际密码")if not res thenngx.say("failed to authenticate: ", err)returnendlocal res, err = red:get(request_uri)-- 请修改https://www.test.com 为实际配置域名或IP端口if res == ngx.null thenngx.say(request_uri)    -- ngx.redirect("http://实际ip/404.html")   returnendif not res then    ngx.say("failed to get: " .. request_uri , err)    returnendred:set_keepalive(6000,1000)ngx.say(res)

在/opt/deploy-script/openresty 目录下 新建nginx.conf文件,并添加如下内容

#新建静态页输出节点,content_by_lua_file为lua脚本实际路径。   server {        listen       80;        server_name  localhost;         #pc端静态响应        location /PC {           default_type text/html;           content_by_lua_file "/usr/local/openresty/nginx/conf/lua/single_connector.lua";            #redis集群请使用此配置            #content_by_lua_file "/usr/local/openresty/nginx/conf/lua/cluster_connector.lua";          }        #wap端静态响应        location /WAP {           default_type text/html;           content_by_lua_file "/usr/local/openresty/nginx/conf/lua/single_connector.lua";            #redis集群请使用此配置           #content_by_lua_file "/usr/local/openresty/nginx/conf/lua/cluster_connector.lua";          }    }

重启openresty

验证

首先在redis中执行如下命令:

set /PC/index.html 'hello pc'set /WAP/index.html 'hello wap'

然后分别访问:

http://ip:8081/PC/index.htmlhttp://ip:8081/WAP/index.html

实际应用是在应用系统后台,商品上架时触发,根据详情页模板读取动态数据,生成商品详情页,然后详情页保存到redis,通过lua读取渲染展示给用户查看。

实际效果如:


nginx中lua进行时间比较_nginx中lua进行时间比较_02


基于Nginx+Lua的总结

个人认为适合开发业务逻辑单一、特定性能提升场景、核心代码行数较少的应用,不适合业务逻辑复杂、功能繁多的业务型或者企业级应用。