iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >mysql执行大量操作时出现无法连接数据库错误处理方案
  • 313
分享到

mysql执行大量操作时出现无法连接数据库错误处理方案

2024-04-02 19:04:59 313人浏览 泡泡鱼
摘要

下面一起来了解下Mysql执行大量操作时出现无法连接数据库错误处理方案,相信大家看完肯定会受益匪浅,文字在精不在多,希望mysql执行大量操作时出现无法连接数据库错误处理方案这篇短内容是你想要的。问题:my

下面一起来了解下Mysql执行大量操作时出现无法连接数据库错误处理方案,相信大家看完肯定会受益匪浅,文字在精不在多,希望mysql执行大量操作时出现无法连接数据库错误处理方案这篇短内容是你想要的。

问题:mysql执行大量的插叙操作时,报无法连接数据库的错误,错误详情如下:

Fatal error: Uncaught exception 'PDOException' with message 'SQLSTATE[HY000] [2003] Can't connect to MySQL server on '127.0.0.1' (99)' in /mnt/Change/www/html/data/conn.PHP:5 Stack trace: #0 /mnt/Change/www/html/data/conn.php(5): PDO->__construct('mysql:host=127....', 'aaa', 'aaa') #1 /mnt/Change/www/html/data/conn.php(12): conn() #2 /mnt/Change/www/html/test/ZB/addHDG.php(22): Sql_Query('select LoopData...') #3 {main} thrown in /mnt/Change/www/html/data/conn.php on line 5 

运行环境:linux+Apache+php+mysql

原因:对MySQL执行操作时,需要连接数据库,连接是需要占用端口的,大量的查询把端口用完了,数据库也就无法连接了 

查看原因:

执行大量的mysql连接时,在linux中执行

netstat -nt

就会看到大量的连接时TIME_OUT状态 

解决办法

第一步:优化mysql,在拿到数据之后,立刻关闭mysql连接

(1)pdo只需要把连接置成null即可

$pdo=new PDO("mysql:host=127.0.0.1;dbname=aaa","aaa","aaa");
//在拿到数据之后执行下面语句即可
$pdo=null; 

第二步:优化linux系统

(1)在/etc/sysctl.cnf中写入下面语句

net.ipv4.tcp_fin_timeout = 2
net.ipv4.tcp_tw_recycle = 1
net.ipv4.tcp_tw_reuse = 1

解释:

net.ipv4.tcp_tw_recycle=1就是打开快速 TIME-WAIT Sockets 回收,即快速回收处于TIME-WAIT的连接,默认值是0,即关闭状态

net.ipv4.tcp_fin_timeout :设置连接超时时间,单位是秒,默认值是60秒

net.ipv4.tcp_tw_reuse =1:允许重新应用处于TIME-WAIT状态的socket用于新的TCP连接,默认值是0,即关闭状态 

(2)在linux中执行

sysctl -p

使上面的配置生效

看完mysql执行大量操作时出现无法连接数据库错误处理方案这篇文章后,很多读者朋友肯定会想要了解更多的相关内容,如需获取更多的行业信息,可以关注我们的数据库栏目。

您可能感兴趣的文档:

--结束END--

本文标题: mysql执行大量操作时出现无法连接数据库错误处理方案

本文链接: https://www.lsjlt.com/news/34926.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作