nginx插件如何实现非阻塞的方式执行耗时操作?
问题描述:
nginx都知道性能给力的原因是建立在其异步非阻塞的基础上实现的,因此开发nginx插件时处理网络请求一定切记阻塞的方式执行某些耗时操作。否则会严重影响nginx性能...
这个问题就来了:如果我想在插件中执行某些耗时操作呢?比如查询数据库(数据库不支持http协议,有特殊协议)?
ps: 我可以开一个线程池,这些阻塞操作扔到池子里,但是有什么办法可以让当前请求处理挂起到nginx框架的事件队列里?当在阻塞操作的回调函数里在发送改变状态,让nginx继续接着刚才的请求继续处理?
感谢
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
数据库查询本质上就是网络通信,本质上只要你socket的read,write都是非阻塞的就没问题。说起来容易实际做起来比较复杂。nginx自身有一些可复用的机制可以实现在http上非阻塞的各种操作。然而像tcp之类的通信,可能并没有现成的。你要自己去写,我感觉比较复杂,而且还要结合在nginx里面。