登录
首页 >  数据库 >  MySQL

一次php脚本执行过程中多次实例化PDO的情景分析

来源:SegmentFault

时间:2023-02-24 18:38:31 399浏览 收藏

你在学习数据库相关的知识吗?本文《一次php脚本执行过程中多次实例化PDO的情景分析》,主要介绍的内容就涉及到MySQL、PHP、MySQL优化、pdo、fpm,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!

情景分析

脚本代码:

CLI执行:

root@78ad0df34cef:/home/www/test# php index.php
连接成功1
连接成功2
连接成功3
保持连接中...
执行结束

在脚本sleep过程中,我们查看mysql的连接信息:

mysql> show processlist;
+----+------+-----------+------+---------+------+----------+------------------+
| Id | User | Host      | db   | Command | Time | State    | Info             |
+----+------+-----------+------+---------+------+----------+------------------+
|  3 | root | localhost | NULL | Query   |    0 | starting | show processlist |
| 24 | root | localhost | test | Sleep   |    6 |          | NULL             |
| 25 | root | localhost | test | Sleep   |    6 |          | NULL             |
| 26 | root | localhost | test | Sleep   |    6 |          | NULL             |
+----+------+-----------+------+---------+------+----------+------------------+
4 rows in set (0.00 sec)

可以看到一个脚本的执行产生了三个数据库连接,但是如果将后面的实例化的pdo实例赋值给之前实例化的pdo实例,则新的连接会替换掉前一个连接,而不会产生新的连接。所以我们在编程过程中,应该避免多次实例化pdo,而产生不必要的数据库性能消耗。

解决方案

  1. 封装一个单例模式的类,该类实例化的过程就是创建pdo连接的过程。我们要建立数据库连接时,不是手动实例化pdo,而是去获取这个类的实例。
  2. 实例化pdo类时,设定 持久连接 参数:

 true
));
?>

PHP官方文档的引用:

很多 web 应用程序通过使用到数据库服务的持久连接获得好处。持久连接在
脚本结束
后不会被关闭,且被缓存,当
另一个使用相同凭证的脚本
连接请求时被重用。
持久连接缓存可以避免每次脚本需要与数据库回话时建立一个新连接的开销,从而让web 应用程序更快。

官方所说的

脚本结束
,在fpm模式下就是指
一次客户端请求的结束
另一个使用相同凭证的脚本
也就可以对应成
另一个使用相同数据库连接凭证的客户端请求
。首先我们要知道,这两次客户端的请求是根据fpm-workers的空闲情况,被分配给某个worker去执行的,所以两次请求被分配到同一个worker的可能性很低。接着,我们阐明下面的情景。

开启持久连接之后,数据库连接是被缓存于fpm进程之中的。如果某个fpm-worker进程中已经缓存了持久连接,此时可能出现如下两种情况:

  • 当脚本中再次执行带 ATTR_PERSISTENT 参数的pdo连接时,会复用之前的连接,而不会产生新的连接。
  • 当脚本中再次执行不带 ATTR_PERSISTENT 参数的pdo连接时,还会再次产生一个新的数据库连接。

以上就是《一次php脚本执行过程中多次实例化PDO的情景分析》的详细内容,更多关于mysql的资料请关注golang学习网公众号!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表