nginx都知道性能给力的原因是建立在其异步非阻塞的基础上实现的,因此开发nginx插件时处理网络请求一定切记阻塞的方式执行某些耗时操作。否则会严重影响nginx性能... 这个问题就来了:如果我想在插件中执行某些耗时操作呢?比如查询数据库(数据库不支持http协议,有特殊协议)? ps: 我可以开一个线程池,这些阻塞操作扔到池子里,但是有什么办法可以让当前请求处理挂起到nginx框架的事件队列里?当在阻塞操作的回调函数里在发送改变状态,让nginx继续接着刚才的请求继续处理? 感谢
nginx都知道性能给力的原因是建立在其异步非阻塞的基础上实现的,因此开发nginx插件时处理网络请求一定切记阻塞的方式执行某些耗时操作。否则会严重影响nginx性能...
这个问题就来了:如果我想在插件中执行某些耗时操作呢?比如查询数据库(数据库不支持http协议,有特殊协议)?
ps: 我可以开一个线程池,这些阻塞操作扔到池子里,但是有什么办法可以让当前请求处理挂起到nginx框架的事件队列里?当在阻塞操作的回调函数里在发送改变状态,让nginx继续接着刚才的请求继续处理?
感谢
数据库查询本质上就是网络通信,本质上只要你socket的read,write都是非阻塞的就没问题。说起来容易实际做起来比较复杂。nginx自身有一些可复用的机制可以实现在http上非阻塞的各种操作。然而像tcp之类的通信,可能并没有现成的。你要自己去写,我感觉比较复杂,而且还要结合在nginx里面。
数据库查询本质上就是网络通信,本质上只要你socket的read,write都是非阻塞的就没问题。说起来容易实际做起来比较复杂。nginx自身有一些可复用的机制可以实现在http上非阻塞的各种操作。然而像tcp之类的通信,可能并没有现成的。你要自己去写,我感觉比较复杂,而且还要结合在nginx里面。