同步非阻塞

ngx.req.read_body()                  -- 同步非阻塞 (1)

local data = ngx.req.get_body_data()
if data then
    ngx.print("body: ", data)        -- 同步非阻塞 (2)
end

(1)和(2)分别是数据是收和发运作,只有收到才能发送,所以是同步的。
但即使因为网络原因没有收到或者发送不出,也不会阻塞干等着,而是做个“记号”,把等待的这段CPU时间用来处理其他请求

单个处理流程是阻塞的,但整个程序却是非阻塞的

多路复用相关资料

单个请求处理来看是分散的、阻塞的,但因为都复用了一个线程里,所以资源的利用率非常高

相关文章:

  • 2021-06-18
  • 2021-08-29
  • 2021-06-03
  • 2022-01-09
  • 2021-11-01
  • 2021-10-31
  • 2021-09-01
  • 2022-02-07
猜你喜欢
  • 2021-06-22
  • 2022-01-08
  • 2021-12-12
  • 2021-11-30
相关资源
相似解决方案