当前位置: 首页 > news >正文

openresty-lua-redis案例

参考地址:https://github.com/openresty/lua-resty-redis

1。新建nginx配置文件:nginx-openresty-lua-redis.conf

指定配置文件:启动命令

[root@localhost nginx]# ./sbin/nginx -p ./ -c conf/nginx-openresty-lua-redis.conf文件内容:[root@localhost nginx]# cat conf/nginx-openresty-lua-redis.confworker_processes  1;error_log logs/error.log;events {worker_connections  1024;}http {include       mime.types;default_type  application/octet-stream;sendfile        on;keepalive_timeout  65;server {listen       8082;server_name  localhost;location / {default_type text/html;content_by_lua_file /usr/local/openresty/nginx/lua/lua-openresty-redis.lua; }}}文件目录[root@localhost nginx]# pwd /usr/local/openresty/nginx[root@localhost nginx]#

2。修改lua文件:

[root@localhost lua]# cat lua-openresty-redis.lua -- 引用resty的redislocal redis = require "resty.redis";local red = redis:new(); -- 连接redislocal ok,err = red:connect("127.0.0.1",6379); if not ok thenngx.say("faild to connect",err);return endok,err = red:set("dKey","dValue"); if not ok thenngx.say("failed to set dKey",err);return endngx.say("dKey set dValue success") return[root@localhost lua]#读取redis的key对应的值[root@localhost lua]# cat lua-openresty-redis.lua -- 引用resty的redislocal redis = require "resty.redis";local red = redis:new(); -- 连接redislocal ok,err = red:connect("127.0.0.1",6379); if not ok thenngx.say("faild to connect",err);return endok,err = red:set("dKey","dValue"); if not ok thenngx.say("failed to set dKey",err);return endok,err = red:get("dKey") if not ok thenngx.say("dKey is null") elsengx.say("dKey's value is :"..ok) endreturn[root@localhost lua]#分析OpenResty响应信息:目的:为了修改以后的响应信息。server {listen 8081; location / {default_type text/html;content_by_lua_block {ngx.say("hi block");}}}

获取请求参数信息:

修改nginx-param.conf[root@localhost nginx]# ./sbin/nginx -p ./ -c conf/nginx-param.conf[root@localhost nginx]# cat conf/nginx-param.conf worker_processes  1;error_log  logs/error.log;events {worker_connections  1024;}http {include       mime.types;default_type  application/octet-stream;server {listen 8081; location / {default_type text/html;content_by_lua_file /usr/local/openresty/nginx/lua/lua-http-param.lua; }}}[root@localhost nginx]#lua-http-param.lua[root@localhost lua]# cat lua-http-param.lua -- 获取get请求的参数local arg = ngx.req.get_uri_args(); for k,v in pairs(arg)dongx.say("key:",k,"   value:",v); end[root@localhost lua]#结合redis实践一下:[root@localhost lua]# cat lua-http-param.lua -- 获取get请求的参数local redis = require "resty.redis";local red = redis:new();red:connect("127.0.0.1",6379);-- 省去链接错误的判断,前面课程中有local arg = ngx.req.get_uri_args(); for k,v in pairs(arg)dongx.say("key:",k,"   value:",v);red:set(k,v); end[root@localhost lua]#

获取请求头参数

获取http请求中header参数。lua脚本:[root@localhost lua]# cat lua-header-param.lua -- 获取header参数local headers = ngx.req.get_headers(); for k,v in pairs(headers)dongx.say("[header] key:",k," value:",v); end[root@localhost lua]#nginx配置修改[root@localhost conf]# cat nginx-param.conf worker_processes  1;error_log  logs/error.log;events {worker_connections  1024;}http {include       mime.types;default_type  application/octet-stream;server {listen 8081; location / {default_type text/html;content_by_lua_file /usr/local/openresty/nginx/lua/lua-header-param.lua;}}}[root@localhost conf]#

获取post body 键值对 参数

nginx配置文件[root@localhost conf]# cat nginx-param.conf worker_processes  1;error_log  logs/error.log;events {worker_connections  1024;}http {include       mime.types;default_type  application/octet-stream;server {listen 8081; location / {default_type text/html;content_by_lua_file /usr/local/openresty/nginx/lua/lua-post-kv-param.lua;}}}[root@localhost conf]#lua代码[root@localhost lua]# cat lua-post-kv-param.lua-- 获取post body kv参数 -- 重要:读取bodyngx.req.read_body();local postArgs = ngx.req.get_post_args(); for k,v in pairs(postArgs)dongx.say("[post] key:",k," value:",v); end[root@localhost lua]#

获取body体信息

lua脚本:[root@localhost lua]# cat lua-post-body-param.lua-- 获取body体参数-- 所有获取body的操作,这个很重要 ngx.req.read_body();local body = ngx.req.get_body_data();ngx.say(body);[root@localhost lua]#nginx配置文件[root@localhost conf]# cat nginx-param.conf worker_processes  1;error_log  logs/error.log;events {worker_connections  1024;}http {include       mime.types;default_type  application/octet-stream;server {listen 8081; location / {default_type text/html;content_by_lua_file /usr/local/openresty/nginx/lua/lua-post-body-param.lua;}}}[root@localhost conf]#

http://www.xdnf.cn/news/1276201.html

相关文章:

  • Python 的列表 list 和元组 tuple 有啥本质区别?啥时候用谁更合适?
  • Ubuntu 安装 Kibana
  • 旅行者1号无线电工作频段
  • MyBatisPlus插件原理
  • MVCC和日志
  • 音视频学习(五十一):AAC编码器
  • C4.5算法:增益率(Gain Ratio)
  • 嵌入式第二十四课!!linux应用软件编程与文件操作!!!
  • Rust 实战四 | Traui2+Vue3+Rspack 开发桌面应用:通配符掩码计算器
  • JAVA+AI简化开发操作
  • Java集合中的 LinkedList
  • 每日任务day0810:小小勇者成长记之武器精炼
  • node.js 学习笔记3 HTTP
  • Django @login_required实现登陆认证
  • C/C++内存管理函数模板
  • 小明的魔法地图:迷宫探险智慧(记忆性递归)
  • 【0基础3ds Max】主工具栏介绍(下)
  • [激光原理与应用-223]:机械 - 机加厂加工机械需要2D还是3D图?
  • Python设计模式 - 装饰模式
  • 六、RuoYi-Cloud-Plus OSS文件上传配置
  • QT常用控件三
  • Qt—— 下载、工具介绍以及新建项目
  • 从0开始的中后台管理系统-5(userList页面功能实现)
  • 40.【.NET8 实战--孢子记账--从单体到微服务--转向微服务】--扩展功能--集成网关--初始化网关
  • Pytorch进阶-timm库-00快速开始
  • (三)全栈(部署)
  • 精准计算Word文档页数的PHP类
  • 数据结构-deque(双端队列)和queue(队列)区别
  • 【npm、yarn、pnpm】特点对比,按需选择
  • Java 后端性能优化实战:从 SQL 到 JVM 调优