OpenResty 配合 Lua 脚本的使用

OpenResty 配合 Lua 脚本的使用实践

在高并发互联网服务中,传统的 Web 服务器往往难以同时兼顾性能与灵活性。而 OpenResty 作为一个基于 Nginx + LuaJIT 的高性能 Web 平台,能够让我们在保持 Nginx 高并发性能的同时,使用 Lua 脚本 动态扩展其功能,从而满足业务快速迭代与复杂逻辑处理的需求。


一、什么是 OpenResty?

OpenResty 是一个将 Nginx 与 LuaJIT 深度集成的 Web 平台。它内置了丰富的第三方模块,例如 ngx_lualua-resty-* 系列库,使得开发者可以在 Nginx 的请求处理阶段灵活地编写 Lua 脚本,实现:

  • 动态路由分发
  • API 网关逻辑
  • 缓存和限流
  • 请求/响应数据处理
  • 与后端数据库、Redis、Kafka 等交互

相比于传统的修改 Nginx C 模块,Lua 的开发效率要高很多。


二、OpenResty 的典型应用场景

  1. API 网关
    使用 Lua 脚本实现动态路由转发、请求鉴权、流量控制等逻辑。

  2. 缓存层
    借助 lua-resty-redislua-resty-memcached,快速实现高性能的本地缓存与分布式缓存。

  3. A/B 测试与灰度发布
    在请求入口动态判定用户群体,进行不同的后端分流。

  4. 安全防护
    可以通过 Lua 脚本编写自定义的 WAF(Web 应用防火墙)规则,拦截恶意请求。


三、基本配置示例

以一个最简单的 Lua 脚本响应示例来说明 OpenResty 的使用。

1. 安装 OpenResty

在 Linux 系统中:

# 以 CentOS 为例
sudo yum install -y yum-utils
sudo yum-config-manager --add-repo https://openresty.org/package/centos/openresty.repo
sudo yum install -y openresty

安装完成后,Nginx 命令替换为:

openresty -v

2. 配置 Nginx + Lua

编辑 OpenResty 配置文件(通常是 /usr/local/openresty/nginx/conf/nginx.conf):

worker_processes  1;events {worker_connections  1024;
}http {server {listen 8080;location /lua {default_type text/html;content_by_lua_block {ngx.say("Hello, OpenResty with Lua!");}}}
}

3. 启动 OpenResty

openresty -p `pwd`/ -c conf/nginx.conf

浏览器访问 http://localhost:8080/lua,就能看到输出:

Hello, OpenResty with Lua!

四、进阶使用:Lua 脚本调用 Redis

下面演示一个更实用的例子:用 Lua 脚本查询 Redis 中的值。

1. 安装 Lua Redis 库

luarocks install lua-resty-redis

2. 配置示例

在 Nginx 配置中加入:

server {listen 8080;location /get_redis {content_by_lua_block {local redis = require "resty.redis"local red = redis:new()red:set_timeout(1000)  -- 1 秒超时local ok, err = red:connect("127.0.0.1", 6379)if not ok thenngx.say("failed to connect: ", err)returnendlocal res, err = red:get("my_key")if not res thenngx.say("failed to get: ", err)returnendif res == ngx.null thenngx.say("key not found")returnendngx.say("redis value: ", res)}}
}

3. 验证效果

先在 Redis 中写入数据:

redis-cli set my_key "Hello Redis"

访问 http://localhost:8080/get_redis,返回结果:

redis value: Hello Redis

五、总结

通过以上示例可以看到,OpenResty + Lua 为我们提供了一个高性能且灵活的 Web 开发平台。它既能承载高并发请求,又能通过 Lua 脚本快速实现复杂逻辑,特别适合需要动态扩展的场景,如 API 网关、缓存服务、安全防护等。

如果你习惯使用 Nginx + 后端应用 的传统模式,可以尝试将一些逻辑下沉到 OpenResty,用 Lua 实现更高效的边缘处理,减轻后端压力。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/98607.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/98607.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

香港券商櫃台系統發展分析與市場觀察

香港券商櫃台系統發展分析與市場觀察 一、市場環境與交易機制變革 2025年以來,香港證券市場表現活躍。港交所現貨市場平均每日成交金額達2,402億港元,同比增長118%。南向交易(港股通)日均成交額佔比提升至23%,單日淨…

AR技术:多行业数字化转型的加速引擎

在数字化浪潮的推动下,增强现实(AR www.teamhelper.cn )技术正突破传统娱乐和游戏领域的局限,成为各行业数字化转型的重要力量。从工业制造到医疗健康,从教育培训到零售购物,AR技术以其独特的虚实融合能力&…

第6篇、Kafka 高级实战:生产者路由与消费者管理

Kafka 高级实战:生产者路由与消费者管理(Python 版)从基础到进阶:深入理解 Kafka 的生产者消息路由、消费者 Offset 管理,以及 Exactly-Once 语义实现 实战导向:提供完整的可运行代码示例,涵盖自…

基于Python读取多个excel竖向拼接为一个excel

在Python中,可以使用pandas库结合glob模块来遍历读取多个Excel文件,并将它们竖向拼接为一个DataFrame对象。以下是完整的实现方法: 文章目录方法1:使用glob匹配文件 pd.concat()方法2:使用列表推导式(更简…

Linux《进程信号(下)》

在之前的Linux《进程信号(上)》当中我们已经了解了进程信号的基本概念以及知道了信号产生的方式有哪些,还了解了信号是如何进行保存的,那么接下来在本篇当中就将继续之前的学习了解信号是如何处理的。除此之外还会了解到中断的概念…

android 性能优化—ANR

ANR产生原理ANR(Application Not Responding)是 Android 对 “应用主线程卡死” 的系统级保护机制: 当 输入事件、广播、服务 等在规定时间内未被处理完毕,SystemServer 会弹框并杀进程,防止整个系统跟着假死。计时起点…

stm32——单总线,DHT11

目录 一、单总线协议的原理和应用 单总线协议指的是只采用一根信道来进行数据传输,通信指的是双方(MCU与传感器)通过一根信道进行数据交互,所以按照数据的传输方向,只能采用半双工通信方式,比较典型的传感器…

css3之grid布局

容器:gird container开启grid布局的元素 项目:grid items容器里面的子元素,不包括后代元素 显式网格(单元格):通过grid-template-columns和grid-template-rows指定的网格,注意项目不等于单元格,…

C++容器:list

一、list的介绍及使用 list是可以在常数范围内在任意位置进行插入和删除的序列式容器,并且该容器可以前后双向迭代。list的底层是双向链表结构,双向链表中每个元素存储在互不相关的独立节点中,在节点中通过指针指向其前一个元素和后一个元素…

STL库——map/set(类函数学习)

ʕ • ᴥ • ʔ づ♡ど 🎉 欢迎点赞支持🎉 个人主页:励志不掉头发的内向程序员; 专栏主页:C语言; 文章目录 前言 一、序列式容器和关联式容器 二、set 系列的使用 2.1、set 和 multiset 参考文档 2.2、set…

计算机网络IP协议

1.TCP协议1.1 确认应答1.2 超时重传1.3 连接管理1.4 滑动窗口1.5 流量控制1.6 拥塞控制 1.7 延时应答1.8 稍带应答1.9 粘包问题1.10 异常情况2.IP协议 网络层2.1 NAT机制下的几种情况:同一个局域网中,内网ip访问 内网 ip,可以的不同局域网中,内网IP访问 内网IP,不行~~外网IP访…

Windows电脑如何查看wifi连接记录及连接时间

查询WIFI 连接的记录 echo netsh wlan show profiles netsh wlan show wlanreport POWERSHELL 脚本 Get-WinEvent -LogName Microsoft-Windows-WLAN-AutoConfig/Operational | Where-Object { $_.Id -in (8001,8002) } | Select-Object TimeCreated, Id, {Name"Action…

【golang学习笔记 gin 】1.2 redis 的使用

安装redis go get -u github.com/gin-gonic/gin go get -u github.com/go-redis/redis/v8创建相关目录 gotest->conifg->database.go->redis.go->controller ->index.go->model->user.go->router->router.gomain.go 封装Redis package config impor…

Java学习之——“IO流“的进阶流之序列化流的学习

一、核心概念:什么是序列化与反序列化?序列化 (Serialization): 将一个对象(在内存中的状态)转换成一个字节序列的过程。这个字节序列包含了对象的数据、对象的类型以及对象中存储的属性等信息。反序列化 (Deserializa…

机器学习04——决策树(信息增益、信息增益率、ID3、C4.5、CART、剪枝、连续值缺失值处理)

上一章:机器学习03——线性模型 下一章:机器学习05——多分类学习与类别不平衡 机器学习实战项目:【从 0 到 1 落地】机器学习实操项目目录:覆盖入门到进阶,大学生就业 / 竞赛必备 文章目录一、决策树的基本流程&#…

(论文速读)从语言模型到通用智能体

论文题目:From Multimodal LLMs to Generalist Embodied Agents: Methods and Lessons(从多模式大型语言模型到多面手具身代理:方法和教训)会议:CVPR2025摘要:我们研究了多模态大型语言模型(Multimodal Large Language…

【Epiq Solutions】Matchstiq™ G20 和 Matchstiq™ G40 AI SDR

Matchstiq™ G20 和 Matchstiq™ G40 产品简介 Matchstiq™ G20 和 Matchstiq™ G40 是 Epiq Solutions 推出的 紧凑型、高性能软件定义无线电(SDR)平台,专为满足 严苛 SWaP-C(体积、重量、功耗受限)场景下的战术与移动…

基于Echarts+HTML5可视化数据大屏展示-旅游智慧中心

效果展示&#xff1a; 代码结构&#xff1a;主要代码实现 index.html布局 <!DOCTYPE html> <html lang"en" style"font-size: 97.5px;"> <head><meta http-equiv"Content-Type" content"text/html; charsetUTF-8"…

Docker 镜像的使用

1.镜像的基本信息[roothost1 ~]# docker images REPOSITORY TAG IMAGE ID CREATED SIZE ubuntu latest 802541663949 2 weeks ago 78.1MB hello-world latest 1b44b5a3e06a 4 weeks ago 10.1kB执行 docker images 命令时加上 --no…

网络编程;套接字;TCP通讯;UDP通讯;0909

思维导图TCP服务器端和客户端通讯服务器端 代码#include<myhead.h> #define SER_IP "192.168.109.12"//我的虚拟机的ip #define SER_PORT 8888 int main() {//1.创建一个用于连接的套接字文件描述符int sfd socket(AF_INET,SOCK_STREAM,0);if(sfd-1){perror(&…