首页  >  问答  >  正文

并发 - nginx插件如何实现非阻塞的方式执行耗时操作?

问题描述:

nginx都知道性能给力的原因是建立在其异步非阻塞的基础上实现的,因此开发nginx插件时处理网络请求一定切记阻塞的方式执行某些耗时操作。否则会严重影响nginx性能...

这个问题就来了:如果我想在插件中执行某些耗时操作呢?比如查询数据库(数据库不支持http协议,有特殊协议)?

ps: 我可以开一个线程池,这些阻塞操作扔到池子里,但是有什么办法可以让当前请求处理挂起到nginx框架的事件队列里?当在阻塞操作的回调函数里在发送改变状态,让nginx继续接着刚才的请求继续处理?

感谢

phpcn_u1582phpcn_u15822683 天前433

全部回复(1)我来回复

  • 迷茫

    迷茫2017-05-16 17:14:26

    数据库查询本质上就是网络通信,本质上只要你socket的read,write都是非阻塞的就没问题。说起来容易实际做起来比较复杂。nginx自身有一些可复用的机制可以实现在http上非阻塞的各种操作。然而像tcp之类的通信,可能并没有现成的。你要自己去写,我感觉比较复杂,而且还要结合在nginx里面。

    回复
    0
  • 取消回复