zoukankan      html  css  js  c++  java
  • 非阻塞 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 10 -n 2000  http://127.0.0.1/sleep_1

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

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

    为什么会这样?

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

  • 相关阅读:
    尽管以C++为基础,但 Java 是一种更纯粹的面向对象程序设计语言
    Java 还是 C++?
    计划的回报
    阶段4:校订
    阶段3:开始创建
    阶段2:如何构建?
    阶段1:要制作什么?
    阶段0:拟出一个计划
    不要迷失
    分析和设计
  • 原文地址:https://www.cnblogs.com/wangzhisdu/p/7771340.html
Copyright © 2011-2022 走看看