非阻塞 sleep

在OpenResty里面选择使用库的时候,有一个基本的原则:尽量使用ngx Lua的库函数,尽量不用Lua的库函数,因为Lua的库都是同步阻塞的。

再来一个例子来说明阻塞API的调用对nginx并发性能的影响

location /sleep_1 {
default_type 'text/plain';
content_by_lua_block {
ngx.sleep(0.01)
ngx.say("ok")
}
}
location /sleep_2 {
default_type 'text/plain';
content_by_lua_block {
function sleep(n)
os.execute("sleep " .. n)
end
sleep(0.01)
ngx.say("ok")
}
}

ab测试一下

ab -c  -n   http://127.0.0.1/sleep_1

非阻塞 sleep

ab -c  -n   http://127.0.0.1/sleep_2

非阻塞 sleep

可以看到,如果不使用ngx_lua提供的sleep函数,nginx并发处理性能会下降10倍以上

为什么会这样?

原因是sleep_1接口使用了ngx_lua提供的非阻塞API,而sleep_2使用了系统自带的阻塞API。前者只会引起(进程内)协程的切换,但进程还是处于运行状态(其他协程还在运行),而后者却会触发进程切换,当前进程会变成睡眠状态, 结果CPU就进入空闲状态。很明显,非阻塞的API的性能会更高。

上一篇:Windows 8.1 文件资源管理器 打开文件夹缓慢,显示文件夹为空,进度条一直加载的解决办法


下一篇:分布式事务的管理--atomikos