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

问题描述:

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

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

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

感谢

阅读 3.6k
1 个回答

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

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题