🔬
OpenResty 最佳实践
  • 序
  • 入门篇
  • Lua 入门
    • Lua 简介
    • Lua 环境搭建
    • Lua 编辑器选择
    • 基础数据类型
    • 表达式
    • 控制结构
      • if/else
      • while
      • repeat
      • for
      • break,return 和 goto
    • Lua 函数
      • 函数的定义
      • 函数的参数
      • 函数返回值
      • 全动态函数调用
    • 模块
    • String 库
    • Table 库
    • 日期时间函数
    • 数学库函数
    • 文件操作
  • Lua 高阶
    • 元表
    • 面向对象编程
    • 局部变量
    • 判断数组大小
    • 非空判断
    • 正则表达式
    • 虚变量
    • 抵制使用 module() 定义模块
    • 调用代码前先定义函数
    • 点号与冒号操作符的区别
    • module 是邪恶的
    • FFI
    • 什么是 JIT
  • Nginx
    • Nginx 新手起步
    • location 匹配规则
    • 静态文件服务
    • 日志
    • 反向代理
    • 负载均衡
    • 陷阱和常见错误
  • OpenResty
    • 环境搭建
      • Windows 平台
      • CentOS 平台
      • Ubuntu 平台
      • Mac OS X 平台
    • Hello World
    • 与其他 location 配合
    • 获取 uri 参数
    • 获取请求 body
    • 输出响应体
    • 日志输出
    • 简单 API Server 框架
    • 使用 Nginx 内置绑定变量
    • 子查询
    • 不同阶段共享变量
    • 防止 SQL 注入
    • 如何发起新 HTTP 请求
    • 如何完成 bit 操作
      • 一,复习二进制补码
      • 二,复习位运算
      • 三,LuaJIT 和 Lua BitOp Api
      • 四,位运算算法实例
      • 五,Lua BitOp 的安装
  • LuaRestyRedisLibrary
    • 访问有授权验证的 Redis
    • select+set_keepalive 组合操作引起的数据读写错误
    • redis 接口的二次封装(简化建连、拆连等细节)
    • redis 接口的二次封装(发布订阅)
    • pipeline 压缩请求数量
    • script 压缩复杂请求
    • 动态生成的 lua-resty-redis 模块方法
  • LuaCjsonLibrary
    • json 解析的异常捕获
    • 稀疏数组
    • 空 table 编码为 array 还是 object
  • PostgresNginxModule
    • 调用方式简介
    • 不支持事务
    • 超时
    • 健康监测
    • SQL 注入
  • LuaNginxModule
    • 执行阶段概念
    • 正确的记录日志
    • 热装载代码
    • 阻塞操作
    • 缓存
    • sleep
    • 定时任务
    • 禁止某些终端访问
    • 请求返回后继续执行
    • 调试
    • 请求中断后的处理
    • 我的 lua 代码需要调优么
    • 变量的共享范围
    • 动态限速
    • shared.dict 非队列性质
    • 正确使用长链接
    • 如何引用第三方 resty 库
    • 典型应用场景
    • 怎样理解 cosocket
    • 如何安全启动唯一实例的 timer
    • 如何正确的解析域名
  • LuaRestyDNSLibrary
    • 使用动态 DNS 来完成 HTTP 请求
  • LuaRestyLock
    • 缓存失效风暴
  • OpenResty 与 SSL
    • HTTPS 时代
    • 动态加载证书和 OCSP stapling
    • TLS session resumption
  • 测试
    • 代码静态分析
    • 单元测试
    • 代码覆盖率
    • API 测试
    • 性能测试
    • 持续集成
    • 灰度发布
      • 分流引擎设计
      • 控制台开发
      • 向运维平台发展
  • Web 服务
    • API 的设计
    • 数据合法性检测
    • 协议无痛升级
    • 代码规范
    • 连接池
    • C10K 编程
    • TIME_WAIT 问题
    • 与 Docker 使用的网络瓶颈
  • 火焰图
    • 什么是火焰图
    • 什么时候使用
    • 如何安装火焰图生成工具
    • 如何定位问题
    • 拓展阅读
    • FAQ
Powered by GitBook
On this page
Edit on GitHub
  1. LuaNginxModule

典型应用场景

可以这样说,任何一个开发语言、开发框架,都有它存在的明确目的,重心是为了解决什么问题。没有说我们学习一门语言或技术,就可以解决所有的问题。同样的,OpenResty 的存在也有其自身适用的应用场景。

其实官网 wiki 已经列了出来:

  • 在 Lua 中混合处理不同 Nginx 模块输出(proxy, drizzle, postgres, Redis, memcached 等)。

  • 在请求真正到达上游服务之前,Lua 中处理复杂的准入控制和安全检查。

  • 比较随意的控制应答头(通过 Lua)。

  • 从外部存储中获取后端信息,并用这些信息来实时选择哪一个后端来完成业务访问。

  • 在内容 handler 中随意编写复杂的 web 应用,同步编写异步访问后端数据库和其他存储。

  • 在 rewrite 阶段,通过 Lua 完成非常复杂的处理。

  • 在 Nginx 子查询、location 调用中,通过 Lua 实现高级缓存机制。

  • 对外暴露强劲的 Lua 语言,允许使用各种 Nginx 模块,自由拼合没有任何限制。该模块的脚本有充分的灵活性,同时提供的性能水平与本地 C 语言程序无论是在 CPU 时间还是在内存占用方面差距都非常小。所有这些都要求 LuaJIT 2.x 是启用的。其他脚本语言实现通常很难达到这一性能水平。

不擅长的应用场景

前面的章节,我们是从它适合的场景出发,OpenResty 不适合的场景又有哪些?以及我们在使用中如何规避这些问题呢?

官网并没有给出答案,这里我根据我们的应用场景给大家列举一些,并简单描述一下原因:

  • 有长时间阻塞调用的过程

    • 例如通过 Lua 完成系统命令行调用

    • 使用阻塞的 Lua API 完成相应操作

  • 单个请求处理逻辑复杂,尤其是需要和请求方多次交互的长连接场景

    • Nginx 的内存池 pool 是每次都新申请内存存放数据

    • 所有的内存释放都是在请求退出的时候统一释放

    • 如果单个请求处理过于复杂,将会有过多内存无法及时释放

  • 内存占用高的处理

    • 受制于 Lua VM 的最大使用内存 2G 的限制

    • 这个限制是单个 Lua VM,也就是单个 Nginx worker

  • 两个请求之间有交流的场景

    • 例如你做个在线聊天,要完成两个用户之间信息的传递

    • 当前 OpenResty 还不具备这个通讯能力(后面可能会有所完善)

  • 与行业专用的组件对接

    • 最好是 TCP 协议对接,不要是 API 方式对接,防止里面有阻塞 TCP 处理

    • 由于 OpenResty 必须要使用非阻塞 API ,所以传统的阻塞 API ,我们是没法直接使用的

    • 获取 TCP 协议,使用 cosocket 重写(重写后的效率还是很赞的)

  • 每请求开启的 light thread 过多的场景

    • 虽然已经是 light thread,但它对系统资源的占用相对还是比较大的

这些适合、不适合信息可能在后面随着 OpenResty 的发展都会有新的变化,大家拭目以待。

Previous如何引用第三方 resty 库Next怎样理解 cosocket

Last updated 2 years ago