百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

php进阶到架构之swoole系列教程(三)mysql连接池

wptr33 2025-06-04 02:10 10 浏览

目录

  • 概述
  • 学习目标
  • mysql连接池应用场景
  • 连接池定义
  • 查看当前mysql连接数
  • 创建连接池代码示例
  • swoole中使用连接池对象
  • php7进阶到架构师相关阅读

概述

这是关于php进阶到架构之swoole系列学习课程:第三节:mysql连接池

学习目标

了解什么是mysql连接池,以及mysql使用场景。能在实际工作使用连接池(数据库连接池,redis连接池等等)解决高并发带来的问题。

mysql连接池应用场景

场景

每秒同时1000个并发,但mysql数据库同时只支持400个连接,这样mysql就会宕机
解决方案

使用连接池,这个连接池建立了300个与mysql的连接对象,这1000个并发有序地共享连接池里的300个连接。

连接池的使用不但解决了mysql在高并发情况下宕机问题,还额外提高了性能。因为和mysql建立连接,消耗较大。使用连接池只需要连接一次mysql。

连接池定义

永不断开,需要程序常驻内存,这就需要借助swoole实现。

数据库连接池是程序启动时,建立足够的数据库连接,并将这些连接组成一个连接。由程序动态的对连接池中的连接进行申请,使用,释放和回补。

查看当前mysql连接数

show processlist

创建连接池代码示例

/**
 * MYSQL连接池,这个类只能被实例化一次(单例模式)
 * Class MysqlConnectionPool
 */
class MysqlConnectionPool
{
    /**
     * 单例对象
     * @var MysqlConnectionPool
     */
    private static $instance;
    /**
     * 连接池连接数量
     * @var int
     */
    private $connNum = 20;

    /**
     * 连接对象列表,即连接池对象列表
     * @var array
     */
    private $connObjList = [];

    /**
     * 可用连接数
     * @var int
     */
    private $avilaConnNum = 20;
    
    /**
     * 构造方法连接mysql,创建20mysql连接
     * MysqlConnectionPool constructor.
     */
    private function __construct()
    {
        for($i=0; $i<$this->connNum; $i++){
            $dsn = "mysql:host=127.0.0.1;dbname=test";
            $this->connObjList[] =  new Pdo($dsn,'root','123456');
        }
    }
    private function __clone()
    {
    }

    /**
     * 获取连接池对象,单例
     * @return MysqlConnectionPool
     */
    public static function getInstance()
    {
        if(is_null(self::$instance)){
            self::$instance = new self();
        }
        return self::$instance;
    }

    //执行sql操作
    public function query($sql)
    {
        if($this->avilaConnNum < 1){
            throw new Exception("暂时没有可用的连接诶,请稍后");
        }
        //从连接池获取一个连接对象,并删除(array_pop)
        $pdo = array_pop($this->connObjList);
        //可用连接数减1
        $this->avilaConnNum --;
        //使用从连接池中取出的mysql连接执行查询,并且把数据取成关联数组
        $rows = $pdo->query($sql)->fetchAll(PDO::FETCH_ASSOC);
        //把mysql连接放回连接池,可用连接数+1
        array_push($this->connObjList,$pdo);
        $this->avilaConnNum ++;
        return $rows;
    }
}

swoole中使用连接池对象

/创建swoole的http服务器对象
$serv = new swoole_http_server('0.0.0.0',8080);
//当浏览器链接点这个http服务器的时候,向浏览器发送helloworld
$serv->on('request', function($request,$response){
    $sql = "SELECT xxx";//实际查询的sql语句
    $rows = MysqlConnectionPool::getInstance()->query($sql);
    $response->end(json_encode($rows));

});
//启动http服务器
$serv->start();

php7进阶到架构师相关阅读

https://www.kancloud.cn/gofor/gofor

最后,欢迎大家留言补充,讨论~~~喜欢小编的话,欢迎点赞、收藏和关注哦~~~///(^v^)\\\~~~

相关推荐

Linux文件系统操作常用命令(linux文件内容操作命令)

在Linux系统中,有一些常用的文件系统操作命令,以下是这些命令的介绍和作用:#切换目录,其中./代表当前目录,../代表上一级目录cd#查看当前目录里的文件和文件夹ls#...

别小看tail 命令,它难倒了技术总监

我把自己以往的文章汇总成为了Github,欢迎各位大佬star...

lnav:基于 Linux 的高级控制台日志文件查看器

lnav是一款开源的控制台日志文件查看器,专为Linux和Unix-like系统设计。它通过自动检测日志文件的格式,提取时间戳、日志级别等关键信息,并将多个日志文件的内容按时间顺序合并显示,...

声明式与命令式代码(声明模式和命令模式)

编程范式中的术语和差异信不信由你,你可能已经以开发人员的身份使用了多种编程范例。因为没有什么比用编程理论招待朋友更有趣的了,所以这篇文章可以帮助您认识代码中的流行范例。命令式编程命令式编程是我们从As...

linux中的常用命令(linux常用命令和作用)

linux中的常用命令linux中的命令统称shell命令shell是一个命令行解释器,将用户命令解析为操作系统所能理解的指令,实现用户与操作系统的交互shell终端:我们平时输入命令,执行程序的那个...

提高工作效率的--Linux常用命令,能够决解95%以上的问题

点击上方关注,第一时间接受干货转发,点赞,收藏,不如一次关注评论区第一条注意查看回复:Linux命令获取linux常用命令大全pdf+Linux命令行大全pdf...

如何限制他人操作自己的电脑?(如何控制别人的电脑不让发现)

这段时间,小猪罗志祥正处于风口浪尖,具体是为啥?还不知道的小伙伴赶紧去补一下最近的娱乐圈八卦~简单来说,就是我们的小罗同事,以自己超强的体力,以及超强的时间管理能力,重新定义了「多人运动」的含义,重新...

最通俗易懂的命令模式讲解(命令模式百科)

我们先不讲什么是命令模式,先通过一个场景来引出命令模式,看看命令模式能解决什么样的问题。现在有一个渣男张三,他有还几个女朋友,你现在是不是还是单身狗,你就说你气不气?然后他需要每天分别叫几个女朋友起床...

互联网大厂后端必看!Spring Boot 中Runtime执行与停止命令?

你是否曾在使用SpringBoot开发项目时,遇到需要执行系统命令的场景?比如调用脚本进行文件处理,又或是启动外部程序?很多后端开发人员会使用Processexec=Runtime.get...

Linux 常用命令(linux常用的20个命令面试)

日志排查类操作命令...

Java字节码指令:if_icmpgt(0xA3)(java字节码使用的汇编语言)

if_icmpgt是Java字节码中的一条条件跳转指令,其全称是"IfIntegerCompareGreaterThan"。它用于比较两个整数值的大小。如果栈顶的第一个...

外贸干货|如何增加领英的曝光量和询盘

#跨境电商#...

golang执行linux命令(golang调用shell脚本)

需求需要通过openssl生成rsa秘钥,然后保存该秘钥。代码实例packagemainimport("io/ioutil""bytes"&...

LINUX磁盘挂载(linux磁盘挂载到windows)

1、使用root用户查看磁盘挂载情况:fdisk-l2、使用df查看当前磁盘挂载情况,根据和fdisk-l的结果进行对比,查看还有那些磁盘未使用3、挂载:mount磁盘挂载路径...

Linux命令学习——nl命令(linux ln命令的使用)

nl命令主要功能为每一个文件添加行号,每一个输入的文件添加行号后发送到标准输出。当没有文件或文件为-时,读取标准输入...