Openresty中的并发模型是什么?
2015-1-31 0:54:48
收藏:0
阅读:136
评论:1
我正在努力理解 openresty(或 nginx)的并发模型。我阅读了[Lua变量作用域](http://wiki.nginx.org/HttpLuaModule#Lua_Variable_Scope),它解释了变量的生命周期,但它没有关于并发访问它们的任何内容。
这很难用言语解释,所以让我试着用代码来解释。想象一下我有这个 Lua 模块:
local counter = {count = 0}
function counter.incr(amount)
counter.count = counter.count + (amount 或 1)
end
return counter
然后我在 openresty 中这样使用它:
server {
location /incr {
content_by_lua '
local counter = require 'counter'
counter.incr(1)
'
}
location /decr {
content_by_lua '
local counter = require 'counter'
counter.incr(-1)
'
}
location /count {
content_by_lua '
local counter = require 'counter'
ngx.write(counter.count)
'
}
}
我想要理解并发模型,以便回答以下问题:
- 如果我对
/incr进行10个并发调用,然后稍后调用/count,我可以确定结果将为10吗(我认为不是,但为什么)? - 如果我同时对
/incr进行10个并发调用,并且同时对/decr进行另外10个调用,我可以确定/count将返回0吗? - 工作线程数如何影响结果?
- 代码发生的阶段如何影响结果(即
init_by_lua而不是content_by_lua)?
点赞
评论区的留言会收到邮件通知哦~
推荐文章
- 如何将两个不同的lua文件合成一个 东西有点长 大佬请耐心看完 我是小白研究几天了都没搞定
- 如何在roblox studio中1:1导入真实世界的地形?
- 求解,lua_resume的第二次调用继续执行协程问题。
- 【上海普陀区】内向猫网络招募【Skynet游戏框架Lua后端程序员】
- SF爱好求教:如何用lua实现游戏内调用数据库函数实现账号密码注册?
- Lua实现网站后台开发
- LUA错误显式返回,社区常见的规约是怎么样的
- lua5.3下载库失败
- 请问如何实现文本框内容和某个网页搜索框内容连接,并把网页输出来的结果反馈到另外一个文本框上
- lua lanes多线程使用
- 一个kv数据库
- openresty 有没有比较轻量的 docker 镜像
- 想问一下,有大佬用过luacurl吗
- 在Lua执行过程中使用Load函数出现问题
- 为什么 neovim 里没有显示一些特殊字符?
- Lua比较两个表的值(不考虑键的顺序)
- 有个lua简单的项目,外包,有意者加微信 liuheng600456详谈,最好在成都
- 如何在 Visual Studio 2022 中运行 Lua 代码?
- addEventListener 返回 nil Lua
- Lua中获取用户配置主目录的跨平台方法
nginx采用基于事件的架构,这意味着它使用单线程1和事件循环来处理套接字,当套接字变得可读或可写时处理它们。这意味着请求实际上并不是同时处理的,但是如果存在任何套接字/IO延迟,即使有延迟,也可以快速一一处理几个请求。
是的。只要所有/ incr请求都完成后再调用/ count,结果就会是10。想象一下,有9个请求已经完成,但是由于某种原因第10个请求被发送者延迟了,如果在nginx处理第10个请求之前处理了/ count,您应该得到9作为结果。
是的,但是不能保证这些请求的处理顺序。请注意,在这种情况下,您不需要锁定状态或使用全局信号量或任何类似的东西。如果读取状态并在将其写回之前进行了一些I/O调用(因为在此期间可能会处理不同的请求),则可能会遇到问题,但是您的示例不是这样做的。
Lua实例在同一工作进程中处理的请求之间共享,因此多个工作进程不会给您相同的结果。您的所有/ incr请求可以转到一个工作进程,但是您的/ count请求可以转到具有不同Lua实例的不同工作进程,该实例仍将
count设置为0。如果需要在实例之间共享数据,您可能需要使用类似[lua_shared_dict](http://wiki.nginx.org/HttpLuaModule#lua_shared_dict)的东西。请查看有关数据共享的部分(http://wiki.nginx.org/HttpLuaModule#Data_Sharing_within_an_Nginx_Worker)以获取其他选项。当主进程加载配置文件时,才会执行
init_by_lua。1我进行了简单化,因为据我所知,它也可以生成多个实例以处理多核系统和某些其他情况。