我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

下面一起来了解下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执行大量操作时出现无法连接数据库错误处理方案这篇文章后,很多读者朋友肯定会想要了解更多的相关内容,如需获取更多的行业信息,可以关注我们的数据库栏目。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

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

下载Word文档

猜你喜欢

关于对连接数据库时出现1130-host “**” is not allowed to connect to this MySql/mariadb server 的错误解决方法

在完成mariadb的搭建后,在端口与防火墙均为正常的情况下,出现了1130- Host xxx is not allowed to connect to this MariaDb server 的情况。 笔者在网络上寻找了许久,最终发现了是因为授权的问题,使
2019-04-28

编程热搜

目录