NGX_LUA的三种变量范围
-
进程间共享, nginx的所有work进程共享,使用lua_shared_dict定义,这样高并发就出触发锁。
-
进程内共享,lua代码中不加local关键字就是全局变量,这样的变量在同一个进程的所有请求之间共享,因为开启了lua缓存,每个work的VM虚拟机都会缓存全局变量.
-
同一个请求,比如local声明的或者ngx.ctx
-
lua_shared_dict 有模块lua-resty-lrucache可以实现在一个work中共享,由于nginx是单进程的,所以永远不会触发锁
就是兼顾效率而且没有锁的问题,缺点内存比进程间共享占用比较大。

本文详细介绍了NGX_LUA中的三种变量范围:进程间共享、进程内共享及同一个请求内的变量作用域。进程间共享变量通过lua_shared_dict定义,适用于所有work进程,但高并发下可能触发锁。进程内共享变量即全局变量,同一进程的所有请求共享,因开启lua缓存,每work进程的VM都会缓存。请求内部变量如local声明或ngx.ctx则仅限于当前请求。此外,lua_shared_dict配合lua-resty-lrucache模块可在单个工作进程中实现高效且无锁的共享。
1787

被折叠的 条评论
为什么被折叠?



