首页 存档 技术 查看内容

PHP中MySQL数据库异步查询实现

2018-3-30 13:00 |来自: 互联网 396 0

摘要: (点击上方公众号,可快速关注) 来源:信海龙 网址:http://www.bo56.com/ 问题 通常一个web应用的性能瓶颈在数据库。因为,通常情况下php中mysql查询是串行的。也就是说,如果指定两条sql语句时,第二条sql语句会 ...

(点击上方公众号,可快速关注)


来源:信海龙

网址:http://www.bo56.com/

问题

通常一个web应用的性能瓶颈在数据库。因为,通常情况下php中mysql查询是串行的。也就是说,如果指定两条sql语句时,第二条sql语句会等到第一条sql语句执行完毕再去执行。这个时候,如果执行2条sql语句,每条执行时间为50ms,全部执行完毕可能需要100ms。既然,主要原因是sql的串行执行导致。那我们是不是可以改变执行方式来提高性能呢?答案是,可以的。我们可以通过异步执行的方式来提高性能。

异步

如果通过异步的方式去执行,可能性能会有很大提升。如果是采用异步的方式,两条sql语句会并发执行,可能就需要60ms就可以执行完毕。

实现

mysqli mysqlnd。php官方实现的mysqlnd中提供了异步查询的方法。分别是:

  • mysqlnd_async_query 发送查询请求

  • mysqlnd_reap_async_query 获取查询结果

这样就可以不必每次发送完查询请求后,一直阻塞等待查询结果了。

实现代码如下:

声明:文章版权归原作者所有 部分文章转自互联网 如有侵权请联系 [邮箱地址] 删除

路过

雷人

握手

鲜花

鸡蛋

相关分类

返回顶部