登录  /  注册

php实现mysql连接池效果步骤详解

php中世界最好的语言
发布: 2018-05-19 14:10:26
原创
2756人浏览过

这次给大家带来php实现mysql连接池效果步骤详解,php实现mysql连接池效果的注意事项有哪些,下面就是实战案例,一起来看一下。

循环从mysql连接池中获取连接,不需要重复创建新的连接。

参考配置修改:可以参考下面的文章

防止访问量过大,把连接数占满了

<?php /**
 * @author xuleyan
 * @title mysql类
 */
class DbHelper{
  //连接池
  private $_pools = [];
  //连接池大小
  const POOLSIZE = 5;
  const USERNAME = "root";
  const PASSWORD = "root";
  const HOST = "127.0.0.1";
  const DB = "test";
  public function construct()  
  {
    $db = self::DB;
    $username = self::USERNAME;
    $password = self::PASSWORD;
    $host = self::HOST;
    //持久化连接
    $presistent = array(PDO::ATTR_PERSISTENT => true);
    for ($i=0; $i _pools, $connection);
    }
  }
  //从数据库连接池中获取一个数据库链接资源
  public function getConnection()
  {
    echo 'get' . count($this-&gt;_pools) . "<br>";
    if (count($this-&gt;_pools) &gt; 0) {
      $one = array_pop($this-&gt;_pools);
      echo 'getAfter' . count($this-&gt;_pools) . "<br>";
      return $one;
    } else {
      throw new ErrorException ( "<mark>数据库连接池中已无链接资源,请稍后重试!</mark>" );
    }
  }
  //将用完的数据库链接资源放回到数据库连接池
  public function release($conn)
  {
    echo 'release' . count($this-&gt;_pools) . "<br>";
    if (count($this-&gt;_pools) &gt;= self::POOLSIZE) {
      throw new ErrorException ( "<mark>数据库连接池已满!</mark>" );
    } else {
      array_push($this-&gt;_pools, $conn);
      // $conn = null;
      echo 'releaseAfter' . count($this-&gt;_pools) . "<br>";
    }
  }
  public function query($sql)
  {
    try {
      $conn = $this-&gt;getConnection();
      $res = $conn-&gt;query($sql);
      $this-&gt;release($conn);
      return $res;
    } catch (ErrorException $e) {
      print 'error:' . $e-&gt;getMessage();
      die;
    }
  }
  public function queryAll($sql)
  {
    try {
      $conn = $this-&gt;getConnection();
      $sth = $conn-&gt;prepare($sql);
      $sth-&gt;execute();
      $result = $sth-&gt;fetchAll();
      return $result;
    } catch (PDOException $e) {
      print 'error:' . $e-&gt;getMessage();
      die;
    }
  }
}
登录后复制

在另外的文件这样调用

<?php  
require_once &#39;db.php&#39;;
$sql = &#39;select * from user&#39;;
$dbhelper = new DbHelper;
for ($i=0; $i < 10; $i++) { 
  $res = $dbhelper->query($sql);
  // var_dump($res) . PHP_EOL;
}
登录后复制

ThinkPHP连接MySQL的连接池使用方法

因为一个小bug,导致项目在某个晚上向mysql发送了大量的连接请求,同时mysql服务器的dns出现问题,导致反解超时。最后活活的把mysql服务器拖挂了。

最后bug修复了,并研究了一下增加 mysql连接池的办法。

这两天搜了一下,发现ThinkPHP文档里没有连接池的相关文档。所以自己研究了下代码。

首先: PHP常用的mysql扩展库有三种 : mysql, mysqli, pdo_mysql.

* mysqli 是不支持连接池的。
* pdo_mysql 支持,但是,thinkPHP的pdo扩展不支持mysql,仅支持:'MSSQL','ORACLE','Ibase','OCI' . ( 见 Pdo.class.php 的第59行)

* mysql 支持,通过方法:mysql_pconnect . (具体参数可以看php官方文档)

1 使ThinkPHP启用 长连接的方式是:

class BaseMysql extends Model {
  protected $connection = array(
    'db_type' =&gt; 'mysql',
    'db_user' =&gt; '***',
    'db_pwd' =&gt; '*******',
    'db_host' =&gt; '*******',
    'db_port' =&gt; '3306',
    'db_name' =&gt; 'custom',
    'db_params' =&gt; array('persist' =&gt; true),
  );
}
登录后复制

如果你认为,配置这个就万事大吉了,那就大错特错了。

2 mysql -> my.cnf修改配置:
[mysqld]

interactive_timeout =60 // 交互连接(mysql-client)的过期时间。
wait_timeout =30 // 长连接的过期时间时间。 这个一定要改啊!默认是8个小时。 如果请求量大点,很快连接数就占满了。
max_connections = 100 //最大连接数,可以认为是连接池的大小

3 php.ini 修改:
[MySql]
mysql.allow_persistent = On
mysql.max_persistent = 99 // 要小于mysql配置的最大连接数
mysql.max_links = 99

4 webserver如果是apache ,需要启用keep-alive。 否则,一旦请求退出,长连接将无法再重用。
webserver 是nginx的情况:
pm = dynamic // 默认启动一些子进程,用于处理http请求。
pm.max_children // 最大的子进程数。 这个配置要小于 mysql 的max_connections。

5 如果发现还是不能用,请检查操作系统的keepalive 是否启用。

综述:

需要 keep-alive 和 数据库长连接同时启用,否则长连接回白白的占用mysql的连接数资源,而无法重用。
对于 nginx + php-fpm 的情况,其实是保持了 php-fpm 子进程与mysql的长连接。 前端的http请求被分配给哪个 php-fpm子进程,该子进程就重用自己与mysql 的长连接。

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

PHP实现多元线性回归模拟曲线算法步骤详解

php双引号中访问数组元素报错如何处理

以上就是php实现mysql连接池效果步骤详解的详细内容,更多请关注php中文网其它相关文章!

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
关于CSS思维导图的课件在哪? 课件
凡人来自于2024-04-16 10:10:18
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号