并发 - nginx插件如何实现非阻塞的方式执行耗时操作?
phpcn_u1582
phpcn_u1582 2017-05-16 17:12:26
0
1
402

问题描述:

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

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

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

感谢

phpcn_u1582
phpcn_u1582

全部回复 (1)
迷茫

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

    最新下载
    更多>
    网站特效
    网站源码
    网站素材
    前端模板
    关于我们 免责声明 Sitemap
    PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!