程序连不上mysql的解决方法


小编给大家分享一下程序连不上mysql的解决方法,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!程序连不上mysql的解决办法:1、确定mysql服务是否正常,并找运维确认网络问题;2、将“max_allowed_packet”值调大;3、将“net_read_timeout”值调大;4、将“connect_timeout”值调大等。程序连不上mysql的问题总结连不上mysql时一般有以下四种报错:一:Can’t connect to MySQL server可能的原因:1,mysql服务端没有启起来2,网络不通(iptables,selinux,网络不稳定)对应的解决方案:1,dba先确定mysql服务是否正常2,mysql服务正常的情况下找运维确认网络问题二: Lost connection to MySQL server有四种情况可能会导致这样的报错:1,网络问题2,查询的结果集太大,比如一个查询要返回几百万个结果3,客户端发起数据库连接的时候由于connect_timeout设置时间太短而报错,如果是由于这个原因引起的报错可以通过SHOW GLOBAL STATUS LIKE ‘A开发云主机域名borted_connects’查看这个值是否有增加4,查询有blob类型,超过了max_allowed_packet参数的限制这四种情况对应的解决方案:1,运维监控网络是否有问题2,将 net_read_timeout值调大3,将connect_timeout值调大4,将max_allowed_packet值调大三: Sorry, due to line fault, temporarily unable to browse, we are dealing with.这个错误不是mysql原生的错误,在网上也没有找到有类似的资料.目前发现有三种情况会有这种报错:1,网络有问题2,数据库连接数过多3,连数据库的帐号密码有误四: MySQL server has gone away有以下12种情况可能会导致这样的报错:1,默认的wait_timeout值为8个小时,如果空闲连接超过这个值会被kill2,dba手动kill3,客户端的帐号没有权限连接mysql server4,客户端TCP/IP连接超时,如使用mysql_options(…, MYSQL_OPT_READ_TIMEOUT,…)或者mysql_options(…, MYSQL_OPT_WRITE_TIMEOUT,…)函数5,当客户端禁用了自动重连接( automatic reconnection)6,查询语句不正确7,查询语句太长,超过了max_allowed_packet的限制8,一条insert或者replace语句更新的行数过多9,域名解析失败10,防火墙屏蔽了3306端口11,一个线程fork了多个子进程,当多个子进程共用一个连接时会导致报错12,mysql服务端挂了报MySQL server has gone away的错误原因比较多,我们可以从三个方面来应对这个问题:1,运维a,确认防火墙规则b,dns服务器无异常d,合理配置php.ini中连接mysql的参数connect_timeout,默认为60smysqli.reconnect,默认为off2,DBAa,确定mysql服务和连接数无异常b,设置合理的wait_timeout值c,设置在服务器端合理的max_allowed_packet值d,确认帐号权限无误3,开发a,建议使用mysqli替代mysqlb,尽量少用长连接c,mysqli.ping()可以在连接断开后自动重连,mysql.ping()从mysql5.0.3后就不支持自动重连了d,子进程之间不要共用一个数据库连接以gamiss为例,我们来看一下max_allowed_packet和超时有关的参数:来看一下这几个与连不上数据库相关的超时参数:connect_timeout:在获取链接时,等待握手的超时时间,一般默认即可(10s),为了避免因为网络不佳导致连接拥塞可以适当增大这个值.线上配置为60swait_timeout/interactive_timeout:连接状态持续为sleep的超时时间,默认为28800(8小时),现上调整到了24小时net_read_timeout:服务器端等待客户端发送数据的超时时间,默认60s,线上为120snet_write_timeout:服务器端写数据到客户端的超时时间,默认60s,线上为120s再看一下max_allowed_packet参数:max_allowed_packet的默认值是1M(1048576),最大值是1G(1073741824),我们目前线上的值已经是上限值了.从上面的配置可以看到这些参数的设置相对来说都很大了,数据库正常情况下程序报连不上数据库应该和数据库本身的参数配置没有关系.我们需要从其它方向来解决这个问题.看完了这篇文章,相信你对程序连不上mysql的解决方法有了一定的了解,想了解更多相关知识,欢迎关注开发云行业资讯频道,感谢各位的阅读!

相关推荐: 如何解决phpmyadmin无法登录的问题

小编给大家分享一下如何解决phpmyadmin无法登录的问题,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!停止mysql服务设置数据库权限为所有人都能登录,即开发云主机域名跳过验证(有兴趣的可以去看下skip -grant命令,我也是一知半解)命…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 06/12 10:08
下一篇 06/12 10:17

相关推荐