php kafka 连接断开多次后 链接不上_php和mysql连接方式(短 长 池)

本文通过实例演示了PHP中短连接和长连接与MySQL交互的区别。短连接在每次请求完成后关闭,而长连接则会缓存连接,用于后续请求重用,以减少连接建立的开销。实验结果显示,短连接导致每次请求产生新的MySQL连接,而长连接则保持连接不变,即使请求结束,连接依然存在。这有助于理解如何根据应用场景选择合适的连接方式以优化数据库性能。
摘要由CSDN通过智能技术生成

一个php work进程只能处理一个请求,当完成一个请求了,才能处理下一次的请求

2.短连接:

执行到php关闭mysql连接的代码时,就断开,否则在处理本次请求结束的时候,释放mysql连接

实验:

<?php
    $dbhost = '127.0.0.1';
    $dbdatabase = 'im';
    $username = 'root';
    $userpass = '123456';

    $dsn='mysql:host='.$dbhost.';dbname='.$dbdatabase.';';
    $dbh=new PDO($dsn,$username,$userpass);
    $stmt=$dbh->query('SELECT id FROM im_fri');
    $row=$stmt->fetch();
    sleep(10);
    var_dump($row);

并发请求: /usr/local/ab/usr/bin/ab -c 100 -n 100 http://192.168.149.130/login/index

结果: 查看mysql连接数: show full processlist
这里我截了php work进程,和两个时刻的mysql连接情况的图片

3c251fb83267c90ebd4d96a670621c9d.png

5191f156b920114c7abdd568d0610a69.png

944dbe7347379efa76d2a885c59f3643.png

一共五个php-fpm进程,mysql有五个连接,连接的id,会递增,说明每次请求完成,mysql连接消失,新的请求,php会重新连接mysql。

3.长连接:

当我们创建的数据连接为PDO持久化连接时,该连接在使用完毕或者PHP脚本结束后并不会被关闭,而是被PHP缓存起来。当另一个使用相同凭证(主机、端口、数据库名、用户名、密码等信息完全一致)的PHP脚本请求建立连接时,PHP将直接返回之前被缓存起来的连接,从而达到连接重用。持久连接缓存可以避免每次访问数据库都要建立一个新连接的开销。

实验:

<?php
    $dbhost = '127.0.0.1';
    $dbdatabase = 'im';
    $username = 'root';
    $userpass = '123456';

    $dsn='mysql:host='.$dbhost.';dbname='.$dbdatabase.';';
    $dbh=new PDO($dsn,$username,$userpass,  [PDO::ATTR_PERSISTENT => true]);
    $stmt=$dbh->query('SELECT id FROM im_fri');
    $row=$stmt->fetch();
    sleep(10);
    var_dump($row);

并发请求: /usr/local/ab/usr/bin/ab -c 100 -n 100 http://192.168.149.130/login/index

结果: 查看mysql连接数: show full processlist
这里我截了php work进程,和两个时刻的mysql连接情况的图片

3c251fb83267c90ebd4d96a670621c9d.png

b399994d69c351931bd54a5c8daca6d9.png

9ef424d1850ae637b7bf20884dba7eee.png

一共五个php-fpm进程,mysql有五个连接,连接的id不会变动,说明每次请求完成,mysql连接不会消失,在每个php-fpm进程中处理新的请求,php会重用以前mysql连接, 请求都结束了,每个php-fpm进程和mysql的连接还是不会断的,一直保持着。

3. 总结

c0788e9dbc4bf7ba27d2d6a7c013f68f.png

以上内容希望帮助到大家,很多PHPer在进阶的时候总会遇到一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微服务、Nginx等多个知识点高级进阶干货需要的可以免费分享给大家

以上内容希望帮助到大家,很多PHPer在进阶的时候总会遇到一些问题和瓶颈,业务代码写多了没有方向感,不知道该从那里入手去提升,对此我整理了一些资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、服务器性能调优、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql优化、shell脚本、Docker、微服务、Nginx等多个知识点高级进阶干货需要的可以免费分享给大家,需要戳这里PHP进阶架构师>>>视频、面试文档免费获取

或 者关注我每天分享技术文章

进阶PHP架构师​www.zhihu.com
847b7489e89212beba59f02f13819d50.png
作者:wangnan
来源:https://www.cnblogs.com/wangweiwen/p/6937318.html
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值