Heim >Backend-Entwicklung >PHP-Tutorial >API-Beschreibung des ngx_lua-Moduls

API-Beschreibung des ngx_lua-Moduls

WBOY
WBOYOriginal
2016-07-30 13:31:221337Durchsuche

ngx_lua-Modul-API-Beschreibung

#Ngx-Befehl
lua_code_cache on |. off;
Funktion: Lua-Code-Cache ein- oder ausschalten, was sich auf die folgenden Anweisungen auswirkt : set_by_lua_file, content_by_lua_file, rewrite_by_lua_file, access_by_lua_file und erzwungenes Laden oder Neuladen von Lua-Modulen usw. Wenn der Cache aktiviert ist, müssen Sie Nginx neu starten, um den LUA-Code zu ändern, aber nicht, wenn er nicht aktiviert ist. Während der Entwicklungsphase ist das Caching grundsätzlich deaktiviert.
Geltungsbereich: Hauptserver, Server, Standort, Standort, wenn
lua_regex_cache_max_entries 1024;
Funktion: Unbekannt (scheint die maximale Grenze für das Zwischenspeichern von Verarbeitungsergebnissen regulärer Ausdrücke zu sein Menge)
lua_package_path .../path... ;
Funktion: Legen Sie den in Lua-Code geschriebenen Erweiterungsbibliothekspfad fest.
Beispiel: lua_package_path '/foo/bar/?.lua;/blah/?.lua;;';
lua_package_cpath '/bar/baz/?.so;/blah/blah /?.so;;';
Funktion: Legen Sie den Lua-Bibliothekspfad der C-Erweiterung fest.
set_by_lua $var '';
set_by_lua_file $var 🎜>
Funktion: Legen Sie eine Nginx-Variable fest. Der Variablenwert wird aus dem Lua-Skript berechnet und per Rückgabe zurückgegeben. Dadurch kann eine komplexe Zuweisungslogik implementiert werden, und der Lua-Code muss sehr schnell sein.
Darüber hinaus können vorhandene NGX-Variablen als Parameter an Lua-Skripte übergeben und über ngx.arg[1], ngx.arg[2] usw. aufgerufen werden.
Geltungsbereich: Hauptserver, Server, Standort, Server wenn, Standort wenn
Verarbeitungsphase: neu schreibencontent_by_lua '';
content_by_lua_file luafile;

Geltungsbereich: Standort, Standort, wenn
Beschreibung: Inhaltsprozessor, empfängt die Anforderungsverarbeitung und gibt eine Antwort aus. content_by_lua wird direkt in die Nginx-Konfigurationsdatei geschrieben. Kürzere Lua Code, letzterer verwendet Lua-Dateien. rewrite_by_lua ''
rewrite_by_lua_file lua_file;

Geltungsbereich: http, Server, Standort, Standort, wenn
Internes URL-Umschreiben durchführen. Schreiben oder externe Umleitung, typischerweise pseudostatisches URL-Umschreiben. Die Standardausführung erfolgt am Ende der Rewrite-Verarbeitungsphase.
Beachten Sie, dass Sie bei Verwendung von rewrite_by_lua das entsprechende Rewrite-Protokoll nicht sehen können, nachdem Sie rewrite_log aktiviert haben. access_by_lua 'lua code';
access_by_lua_file lua_file.lua;

Funktion: Wird für die Zugriffskontrolle verwendet. Wenn wir beispielsweise nur den Intranet-IP-Zugriff zulassen, können Sie das folgende Formular verwenden.
access_by_lua '
if ngx.req.get_uri_args()["token"] ~= "123" then
return ngx.exit(403)
end ';
Scope: http, server, location, location ifheader_filter_by_lua 'lua code ' ;
header_filter_by_lua_file path_file.lua;

Funktion: Header und Cookie setzen;lua_need_request_body on|off;

Funktion: Ob der Anfragetext gelesen werden soll , Es hat einen ähnlichen Effekt wie die Funktion ngx.req.read_body(), diese Methode wird jedoch nicht offiziell empfohlen. lua_shared_dict shared_data 10m;

Funktion: Richten Sie eine gemeinsame globale Variablentabelle ein, die von allen Arbeitsprozessen gemeinsam genutzt werden soll. Der Zugriff kann in einem Lua-Skript wie folgt erfolgen:
Beispiel: local shared_data = ngx.shared.shared_data
10m Ich weiß nicht, was es bedeutet. init_by_lua 'lua code';
init_by_lua_file lua_file.lua;

Geltungsbereich: http
Beschreibung: Wird ausgeführt, wenn der Ginx-Master-Prozess die Konfiguration lädt; Wird normalerweise verwendet, um die globale Konfiguration zu initialisieren/das Lua-Modul vorab zu laden >Beschreibung: Ein Timer, der beim Start jedes Nginx-Worker-Prozesses aufgerufen wird. Wenn der Master-Prozess nicht zulässig ist, wird er normalerweise nur zum regelmäßigen Abrufen von Konfigurationen/Daten oder für Zustandsprüfungen von Back-End-Diensten verwendet.
####################

Methoden und Konstanten
#### ## ###############

#Referenzdokument:

http://wiki.nginx.org/ HttpLuaModuleZh#Core_constants ngx_lua offizielles Dokument

http://blog.csdn.net/imlsz/article/details/42915473 Übersetzung des Hauptinhalts der offiziellen APIhttp://jinnianshilongnian.iteye.com/blog/2186448 Ja Die Dokumentation zur Verwendung von ngx_lua enthält detaillierte Beispiele http://www.cnblogs.com/wangxusummer/p/4309007.html Eine kurze Einführung in die Modulmethode von ngx_lua

Urheberrechtserklärung: Dieser Artikel ist ein Blog Dies ist ein Originalartikel und darf nicht ohne die Erlaubnis des Bloggers reproduziert werden.
ngx.arg[index]  			#ngx指令参数,当这个变量在set_by_lua或者set_by_lua_file内使用的时候是只读的,指的是在配置指令输入的参数.
ngx.var.varname  			#读写NGINX变量的值,最好在lua脚本里缓存变量值,避免在当前请求的生命周期内内存的泄漏
ngx.config.ngx_lua_version 	#当前ngx_lua模块版本号
ngx.config.nginx_version 	#nginx版本
ngx.worker.exiting 			#当前worker进程是否正在关闭
ngx.worker.pid				#当前worker进程的PID
ngx.config.nginx_configure	#编译时的./configure命令选项
ngx.config.prefix 			#编译时的prefix选项

core constans:				#ngx_lua 核心常量
	ngx.OK (0)
	ngx.ERROR (-1)
	ngx.AGAIN (-2)
	ngx.DONE (-4)
	ngx.DECLINED (-5)
	ngx.nil
http method constans:		#经常在ngx.location.catpure和ngx.location.capture_multi方法中被调用.
	ngx.HTTP_GET
	ngx.HTTP_HEAD
	ngx.HTTP_PUT
	ngx.HTTP_POST
	ngx.HTTP_DELETE
	ngx.HTTP_OPTIONS  
	ngx.HTTP_MKCOL    
	ngx.HTTP_COPY      
	ngx.HTTP_MOVE     
	ngx.HTTP_PROPFIND 
	ngx.HTTP_PROPPATCH 
	ngx.HTTP_LOCK 
	ngx.HTTP_UNLOCK    
	ngx.HTTP_PATCH   
	ngx.HTTP_TRACE  
http status constans: 		#http请求状态常量 
	ngx.HTTP_OK (200)
	ngx.HTTP_CREATED (201)
	ngx.HTTP_SPECIAL_RESPONSE (300)
	ngx.HTTP_MOVED_PERMANENTLY (301)
	ngx.HTTP_MOVED_TEMPORARILY (302)
	ngx.HTTP_SEE_OTHER (303)
	ngx.HTTP_NOT_MODIFIED (304)
	ngx.HTTP_BAD_REQUEST (400)
	ngx.HTTP_UNAUTHORIZED (401)
	ngx.HTTP_FORBIDDEN (403)
	ngx.HTTP_NOT_FOUND (404)
	ngx.HTTP_NOT_ALLOWED (405)
	ngx.HTTP_GONE (410)
	ngx.HTTP_INTERNAL_SERVER_ERROR (500)
	ngx.HTTP_METHOD_NOT_IMPLEMENTED (501)
	ngx.HTTP_SERVICE_UNAVAILABLE (503)
	ngx.HTTP_GATEWAY_TIMEOUT (504) 

Nginx log level constants:		#错误日志级别常量 ,这些参数经常在ngx.log方法中被使用.
	ngx.STDERR
	ngx.EMERG
	ngx.ALERT
	ngx.CRIT
	ngx.ERR
	ngx.WARN
	ngx.NOTICE
	ngx.INFO
	ngx.DEBUG

##################
#API中的方法:
##################
print()							#与 ngx.print()方法有区别,print() 相当于ngx.log()
ngx.ctx 						#这是一个lua的table,用于保存ngx上下文的变量,在整个请求的生命周期内都有效,详细参考官方
ngx.location.capture() 			#发出一个子请求,详细用法参考官方文档。
ngx.location.capture_multi() 	#发出多个子请求,详细用法参考官方文档。
ngx.status 						#读或者写当前请求的相应状态. 必须在输出相应头之前被调用.
ngx.header.HEADER 				#访问或设置http header头信息,详细参考官方文档。
ngx.req.set_uri() 				#设置当前请求的URI,详细参考官方文档
ngx.set_uri_args(args) 			#根据args参数重新定义当前请求的URI参数.
ngx.req.get_uri_args()			#返回一个LUA TABLE,包含当前请求的全部的URL参数
ngx.req.get_post_args()			#返回一个LUA TABLE,包括所有当前请求的POST参数
ngx.req.get_headers()			#返回一个包含当前请求头信息的lua table.
ngx.req.set_header()			#设置当前请求头header某字段值.当前请求的子请求不会受到影响.
ngx.req.read_body()				#在不阻塞ngnix其他事件的情况下同步读取客户端的body信息.[详细]
ngx.req.discard_body()			#明确丢弃客户端请求的body
ngx.req.get_body_data()			#以字符串的形式获得客户端的请求body内容
ngx.req.get_body_file()   	 	#当发送文件请求的时候,获得文件的名字
ngx.req.set_body_data()			#设置客户端请求的BODY
ngx.req.set_body_file()			#通过filename来指定当前请求的file data。
ngx.req.clear_header()			#清求某个请求头
ngx.exec(uri,args)				#执行内部跳转,根据uri和请求参数
ngx.redirect(uri, status)		#执行301或者302的重定向。
ngx.send_headers()				#发送指定的响应头
ngx.headers_sent 				#判断头部是否发送给客户端ngx.headers_sent=true
ngx.print(str)					#发送给客户端的响应页面
ngx.say()						#作用类似ngx.print,不过say方法输出后会换行
ngx.log(log.level,...)			#写入nginx日志
ngx.flush()						#将缓冲区内容输出到页面(刷新响应)
ngx.exit(http-status)			#结束请求并输出状态码
ngx.eof()						#明确指定关闭结束输出流
ngx.escape_uri()				#URI编码(本函数对逗号,不编码,而php的urlencode会编码)
ngx.unescape_uri()				#uri解码
ngx.encode_args(table)			#将tabel解析成url参数
ngx.decode_args(uri)			#将参数字符串编码为一个table
ngx.encode_base64(str)			#BASE64编码
ngx.decode_base64(str)			#BASE64解码
ngx.crc32_short(str)			#字符串的crs32_short哈希
ngx.crc32_long(str)				#字符串的crs32_long哈希
ngx.hmac_sha1(str)				#字符串的hmac_sha1哈希
ngx.md5(str)					#返回16进制MD5
ngx.md5_bin(str)				#返回2进制MD5
ngx.today()						#返回当前日期yyyy-mm-dd
ngx.time()						#返回当前时间戳
ngx.now()						#返回当前时间
ngx.update_time()				#刷新后返回
ngx.localtime()					#返回 yyyy-mm-dd hh:ii:ss
ngx.utctime()					#返回yyyy-mm-dd hh:ii:ss格式的utc时间
ngx.cookie_time(sec)			#返回用于COOKIE使用的时间
ngx.http_time(sec)				#返回可用于http header使用的时间		
ngx.parse_http_time(str)		#解析HTTP头的时间
ngx.is_subrequest 				#是否子请求(值为 true or false)
ngx.re.match(subject,regex,options,ctx)  	#ngx正则表达式匹配,详细参考官网
ngx.re.gmatch(subject,regex,opt)			#全局正则匹配
ngx.re.sub(sub,reg,opt)			#匹配和替换(未知)
ngx.re.gsub()					#未知
ngx.shared.DICT 				#ngx.shared.DICT是一个table 里面存储了所有的全局内存共享变量
	ngx.shared.DICT.get	 
	ngx.shared.DICT.get_stale	 
	ngx.shared.DICT.set	 
	ngx.shared.DICT.safe_set	 
	ngx.shared.DICT.add	 
	ngx.shared.DICT.safe_add	 
	ngx.shared.DICT.replace	 
	ngx.shared.DICT.delete	 
	ngx.shared.DICT.incr	 
	ngx.shared.DICT.flush_all	 
	ngx.shared.DICT.flush_expired	 
	ngx.shared.DICT.get_keys
ndk.set_var.DIRECTIVE			#不懂

Das Obige stellt die API-Beschreibung des ngx_lua-Moduls einschließlich des relevanten Inhalts vor. Ich hoffe, dass es für Freunde hilfreich ist, die sich für PHP-Tutorials interessieren.



Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn