NGINX openrestry

Stella981
• 阅读 812

nginx中的变量:

在Nginx配置中,变量只能存放一种类型的值,因为也只存在一种类型的值,那就是字符串。

Nginx变量创建或者定义发生在nginx启动阶段,赋值操作只会发生在请求实际处理的时候

在lua脚本里面引用nginx变量是需要使用ngx.var.name的方式

lua当中的ngx.say和nginx当中的echo是一样的道理(都是作为请求的响应体输出的)

echo是支持变量插值的;content_by_lua 配置指令并不支持参数的“变量插值”功能。

首先,nginx的变量分为两种,一种是内置变量,另一种是用户自定义变量。

1、内置变量:

nginx的内置变量,就是nginx自己定义的变量

内置变量的arg_name参数如果不存在或者值为空字符串,nginx都会输出空字符串;但是在lua当中可以区分开,不存在值为nil,值为为空字符串就是空字符串。

Nginx 会在匹配参数名之前,自动把原始请求中的参数名调整为全部小写的形式。

内置变量$args. 这个变量在读取时返回当前请求的 URL 参数串(可以说是arg_name的集合)

2、自定义变量:

用户自定义变量,必须先定义后使用;不定义直接使用会报错。定义的时候使用set语句并且赋值。

set $test "hello ";定义并赋值
set $b "$test, $test";
echo "${test}world";
echo "$test flank";变量插值

nginx中的变量,如果只是定义了,但没有赋值,使用时会输出空字符串。

但是如果在lua脚本里引用了未定义的自定义变量,也是不会出错的,只是这个时候变量的值为nil

3、可见性和作用域:

可见性:Nginx 变量一旦创建,其变量名的可见范围就是整个 Nginx 配置,甚至可以跨越不同虚拟主机的 server 配置块;,但每个请求都有所有变量的独立副本。

作用域:nginx的变量的作用域是和某一个外部请求或者子请求所绑定的但是不和内部调用所绑定,
内部调用(echo_exec /bar;rewrite ^ /bar;)相当于goto
子请求(echo_location /foo;)把一个请求分为多个请求执行
Nginx 变量值容器的生命期是与当前正在处理的请求绑定的,而与 location 无关。
缓存所依赖的变量的值容器,是与当前请求绑定的。

4、ngx中的ctx变量

ngx.ctx可以用于单个请求内同一工作进程不同阶段共享数据。单个请求内的 rewrite (重写),access (访问),和 content (内容) 等各处理阶段是保持一致的。另外,要注意的是,每个请求,包括子请求,都有一份自己的 ngx.ctx 表

参考文献:

http://www.freecls.com/a/2712/f0

nginx_lua模块原理:https://www.cnblogs.com/wangxusummer/p/4309007.html

nginx+Lua开发入门:https://blog.csdn.net/jinnianshilongnian/article/details/84702680

openresty最佳实践:https://moonbingbing.gitbooks.io/openresty-best-practices/content/

nginx+lua的执行顺序和步骤说明:https://blog.csdn.net/wlgy123/article/details/49815531

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Nginx配置https
一、开启nginx的ssl模块1.未安装过nginx,编译安装配置参数如下:./configure\prefix/usr/local/nginx\withpcre\withhttp\_ssl\_modulessl模块\withhttp\_stub\_status\_module\wit
Wesley13 Wesley13
3年前
4. Nginx模块
Nginx官方模块1.ngx\_http\_stub\_status\_modulehttp://nginx.org/en/docs/http/ngx\_http\_stub\_status\_module.html。(https://www.oschina.net/action/GoToLink?urlhttp%3A%2
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
为什么mysql不推荐使用雪花ID作为主键
作者:毛辰飞背景在mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一),而是推荐连续自增的主键id,官方的推荐是auto_increment,那么为什么不建议采用uuid,使用uuid究
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这