Nginx结合Lua脚本,直接绕过Tomcat应用服务器,连接MySQL/Redis直接获取数据,再结合Lua中Template组件,直接写入动态数据,渲染成页面,响应前端,一次请求响应过程结束。最终达到下图的一个效果。

OpenResty组件

OpenResty的自带组件库默认已经集成了相当实用的组件,http://openresty.org/cn/components.html,如下所示:

  • LuaCjsonLibrary

  • LuaRestyMemcachedLibrary

  • LuaRestyMySQLLibrary

  • LuaRestyRedisLibrary

  • LuaRestyWebSocketLibrary

  • LuaRestyLimitTrafficLibrary

  • 其它等等

Lua-mysql 连接mysql

Lua直接连接MySQL的代码,再结全上一篇中连接Redis的代码,可以完成从后端动态的索取数据。


  1. --测试连接mysql,获取数据

  2. local function close_db(db)

  3.    if not db then

  4.        return

  5.    end

  6.    db:close()

  7. end

  8. //引入mysql组件

  9. local mysql = require("resty.mysql")

  10. local json = require("dkjson")

  11. local db, err = mysql:new()

  12. if not db then

  13.    ngx.say("error : ", err)

  14.    return

  15. end

  16. db:set_timeout(1000)

  17. local props = {

  18.    host = "192.168.1.104",

  19.    port = 3306,

  20.    database = "sonar",

  21.    user = "root",

  22.    password = "root"

  23. }

  24. local res, err, errno, sqlstate = db:connect(props)

  25. if not res then

  26.   ngx.say("connect error : ", err, " , errno : ", errno, " , sqlstate : ", sqlstate)

  27.   return close_db(db)

  28. end

  29. local select_sql = "select * from dashboards"

  30. res, err, errno, sqlstate = db:query(select_sql)

  31. if not res then

  32.   ngx.say("select error : ", err, " , errno : ", errno, " , sqlstate : ", sqlstate)

  33.   return close_db(db)

  34. end

  35. for i, row in ipairs(res) do  

  36.   for name, value in pairs(row) do  

  37.     ngx.say("select row =", i, " : ", name, " = ", value, "<br/>")  

  38.   end  

  39. end  

  40. close_db(db)

Lua-template 模板技术

通过Lua从后端动态取数,需要将数据渲染到静态页面,此时需要引入Template组件,该组件已经在OpenResty中引入,所以勿须再次安装,直接使用即可。


  1. --测试template组件,填充一些变量数据

  2. local template = require("resty.template")

  3. local context = {who = "guooo",from="usgrouping",jsons= {aaaa=123,bbbbb=23234}}  

  4. //此处可调用mysql/redis,一同将数据写入template3.html文件中

  5. template.render("template3.html", context)

再看下静态页面模板长什么样:


  1. {(header.html)}  

  2. <!doctype html>

  3. <html lang="en">

  4. <head>

  5.  <meta charset="UTF-8">

  6.  <meta name="Generator" content="EditPlus®">

  7.  <meta name="Author" content="usgrouping">

  8.  <meta name="Keywords" content="usgrouping,guooo">

  9.  <title>lua-template test</title>

  10. </head>

  11. <body>

  12.   <div>你好{{who}},this is template page 3</div>

  13.  <br/>

  14.   <div>欢迎关注公众号:{{from}}</div>

  15.    <br/>

  16.    <br/>

  17.      {{jsons}}

  18. </body>

  19. </html>

  20. {(footer.html)}  

  21. 其中header.html及footer.html是常用的头部和底部文件,这里只是简单的文本展示

经过上面的两大步,基本上就完成了动态数据经由Lua直接处理渲染成静态页面响应给前端,大大提高了执行效率。

有同学看了上一篇的例子,同时结合Lua连接mysql的例子发现,都是直接连接mysql/redis,而没有通过连接池的形式,其实完全可以使用连接池的形式,只不过此处为了说明原理,采用了直连的形式。

》》》点击左下方的原文链接获取源码及相关资料。

Nginx+Lua+MySQL/Redis实现高性能动态网页展现的更多相关文章

  1. nginx lua mysql redis设置

    最近公司网站改版,程序和数据库全部用新版,旧版的数据要导入,旧网站的30万条数据url要全部重定向到新版网站,正好前段时间在学习nginx+lua+mysql+memcache(redis),找资料真 ...

  2. 使用Nginx Lua实现redis高性能http接口

    使用Nginx Lua实现redis高性能http接口 时间 -- :: 峰云就她了 原文 http://xiaorui.cc/2015/01/27/使用nginx-lua实现redis高性能http ...

  3. 从docker到docker-compose部署一个nginx+flask+mysql+redis应用

    目的是把一个flask项目的mysql数据库.redis数据库.flask应用.nginx服务分别装到四个容器中,然后用docker-compose命令同时启动与关闭 一.安装docker Docke ...

  4. 基于nginx + lua实现的反向代理动态更新

    大家都知道,nginx是当前应用非常广泛的web服务器,热度因为他的高并发高性能高可靠性,且轻量级!牛逼的不行,不多说这些. 今天要介绍的是,如何基于nginx和lua脚本,也就是在openresty ...

  5. Nginx+Php-fpm+MySQL+Redis源代码编译安装指南

    说明:本教程主要包括以下三个部分: 1. 源代码编译安装Nginx 2. 源代码编译安装php以及mysql.redis扩展模块 3. 配置虚拟主机 文中所涉及安装包程序均提供下载链接,欢迎使用 运行 ...

  6. Nginx+Php-fpm+MySQL+Redis源码编译安装指南

    说明:本教程由三部分组成如下: 1.      源码编译安装Nginx 2.      源码编译安装php以及mysql.redis扩展模块 3.      配置虚拟主机 文中所涉及安装包程序均提供下 ...

  7. windows本地搭建nginx+php+mysql+redis环境详细步骤

    1.mysql的下载和安装 这个可参考我另外一篇文章:http://www.cnblogs.com/myIvan/p/9265645.html 2.php的下载和配置修改 下载地址:https://w ...

  8. ubuntu18.04+gunicorn+nginx+supervisor+mysql+redis安装django项目

    Ubuntu18.04 install Django project 项目准备: ECS 实例 (云服务器) 此安装部署方案适合本地ubuntu18.04系统安装和虚拟机中ubuntu18.04系统安 ...

  9. [nginx]lua操作redis

    local redis = require "resty.redis" local red = redis:new() red:set_timeout() -- sec -- or ...

随机推荐

  1. Win8 Metro(C#)数字图像处理--2.65形态学轮廓提取算法

    原文:Win8 Metro(C#)数字图像处理--2.65形态学轮廓提取算法  [函数名称]   形态学轮廓提取函数       WriteableBitmap Morcontourextract ...

  2. Database Comparer VCL 6.4.908.0 D5-XE10.1

    Database Comparer VCL compares and synchronizes databases structure (metadata) and table data for ma ...

  3. UWP-磁贴初识

    原文:UWP-磁贴初识 简单的磁贴内容实现,来自 Bob 的视频. 为一个按钮添加点击事件,来更新磁贴. private void ChangeTileContentButton_Click(obje ...

  4. JS浏览器滚轮事件实现横向滚动照片展

    if(window.attachEvent){ ///*IE8注册事件*/ this.oc.attachEvent('onmousewheel',function(e) { //函数体 }); } e ...

  5. Linux简单文本处理

    tr命令:tr [option] set1 [set2] 删除或者替换set1中的字符在文本表示这个问题中,windows系统下,\r\n为换行:而linux系统下,\n为换行.win->lin ...

  6. Delphi 7.0常用函数速查手册(磁盘文件类)

    在Delphi 7.0中,已为我们定义好了非常多的函数,大致分类有6种:数据类型转换函数.字符串.数组操作函数.文件.磁盘操作函数.内存.指针操作函数.数学运算函数.日期函数. 在Delphi中调用函 ...

  7. Delphi中Menu设置Images属性后快捷按键下划线被隐藏解决方法

    现象:MainMenu设置Images属性后,看不到快捷按键的下划线,如:新建(&N) 分析:VCL中Menus.pas单元的代码,看到如下语句procedure TMenuItem.Adva ...

  8. 阻止系统自动睡眠的小软件,附C#制作过程(执行SetThreadExecutionState API函数,让系统误判)

    因为有时下载东西的时候,不想让电脑自动深入睡眠,所以就开启了离开模式.这样不但不节能环保,而且到真正想要睡眠的时候就是一翻蛋疼. 改过自新,关闭了离开模式,同时无操作30分钟后也会进入睡眠模式.但是在 ...

  9. 学习Java,容易被你忽略的小细节(2)

    昨天心情真的太糟糕了,写完<学习Java,值得注意你注意的问题(1)>之后,迎来些许的支持以后就是一片片的谴责.我的主页上涌现出许许多多Java方面的牛人,谴责我水平太低,写的问题太初级. ...

  10. modelform组件以及ChoiceField属性

    一. Forms组件补充 1.__init__() 如果继承forms.Form的类中的每一个字段,或者大部分字段都做了相同的约束,可以将该约束放到__init__中编写 实例:每一个字段都需要添加f ...