iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >程序连不上mysql的解决方法
  • 616
分享到

程序连不上mysql的解决方法

2024-04-02 19:04:59 616人浏览 安东尼
摘要

小编给大家分享一下程序连不上Mysql的解决方法,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!程序连不上mysql的解决办法:1、确定mysql服务是否正常,并找运维确认网络问题;2、将“ma

小编给大家分享一下程序连不上Mysql的解决方法,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!

程序连不上mysql的解决办法:1、确定mysql服务是否正常,并找运维确认网络问题;2、将“max_allowed_packet”值调大;3、将“net_read_timeout”值调大;4、将“connect_timeout”值调大等。

程序连不上mysql的问题总结

连不上mysql时一般有以下四种报错:

1:Can't connect to MySQL Server
2:Lost connection to MySQL server
3:Sorry, due to line fault, temporarily unable to browse, we are dealing with.
4:MySQL server has Gone away

一: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 'Aborted_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个小时,如果空闲连接超过这个值会被kill

2,dba手动kill

3,客户端的帐号没有权限连接mysql server

4,客户端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,默认为60s

mysqli.reconnect,默认为off

2,DBA

a,确定mysql服务和连接数无异常

b,设置合理的wait_timeout值

c,设置在服务器端合理的max_allowed_packet值

d,确认帐号权限无误

3,开发

a,建议使用mysqli替代mysql

b,尽量少用长连接

c,mysqli.ping()可以在连接断开后自动重连,mysql.ping()从mysql5.0.3后就不支持自动重连了

d,子进程之间不要共用一个数据库连接

以gamiss为例,我们来看一下max_allowed_packet和超时有关的参数:

>show variables like 'max_allowed_packet';
+--------------------+------------+
| Variable_name | Value |
+--------------------+------------+
| max_allowed_packet | 1073741824 |
+--------------------+------------+
>show variables like '%timeout%';
+-----------------------------+----------+
| Variable_name | Value |
+-----------------------------+----------+
| connect_timeout | 60 |
| delayed_insert_timeout | 300 |
| have_statement_timeout | YES |
| innodb_flush_log_at_timeout | 1 |
| innodb_lock_wait_timeout | 120 |
| innodb_rollback_on_timeout | OFF |
| interactive_timeout | 86400 |
| lock_wait_timeout | 31536000 |
| net_read_timeout | 120 |
| net_write_timeout | 120 |
| rpl_stop_slave_timeout | 31536000 |
| slave_net_timeout | 3600 |
| thread_pool_idle_timeout | 60 |
| wait_timeout | 86400 |
+-----------------------------+----------+

来看一下这几个与连不上数据库相关的超时参数:

connect_timeout:在获取链接时,等待握手的超时时间,一般默认即可(10s),为了避免因为网络不佳导致连接拥塞可以适当增大这个值.线上配置为60s

wait_timeout/interactive_timeout:连接状态持续为sleep的超时时间,默认为28800(8小时),现上调整到了24小时

net_read_timeout:服务器端等待客户端发送数据的超时时间,默认60s,线上为120s

net_write_timeout:服务器端写数据到客户端的超时时间,默认60s,线上为120s

再看一下max_allowed_packet参数:max_allowed_packet的默认值是1M(1048576),最大值是1G(1073741824),我们目前线上的值已经是上限值了.

从上面的配置可以看到这些参数的设置相对来说都很大了,数据库正常情况下程序报连不上数据库应该和数据库本身的参数配置没有关系.我们需要从其它方向来解决这个问题.

看完了这篇文章,相信你对程序连不上mysql的解决方法有了一定的了解,想了解更多相关知识,欢迎关注编程网数据库频道,感谢各位的阅读!

您可能感兴趣的文档:

--结束END--

本文标题: 程序连不上mysql的解决方法

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

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

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

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

下载Word文档
猜你喜欢
  • 程序连不上mysql的解决方法
    小编给大家分享一下程序连不上mysql的解决方法,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!程序连不上mysql的解决办法:1、确定mysql服务是否正常,并找运维确认网络问题;2、将“ma...
    99+
    2022-10-18
  • 解决ip连不上mysql的方法
    小编给大家分享一下解决ip连不上mysql的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!解决ip连不上mysql的方法:首...
    99+
    2022-10-18
  • php中mysql连接不上的解决方法
    这篇文章主要介绍了php中mysql连接不上的解决方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。php mysql连接不上的解决办法:1、建立一个PHP文件显示“phpi...
    99+
    2023-06-25
  • 安卓连接不上mysql的解决方法
    这篇文章给大家分享的是有关安卓连接不上mysql的解决方法的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。安卓连接不上mysql的解决办法:首先在Activivty中自定义监听事件...
    99+
    2022-10-18
  • mysql连接不上数据库的解决方法
    小编给大家分享一下mysql连接不上数据库的解决方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!解决方法:首先按下键盘上的“w...
    99+
    2022-10-18
  • MYSQL不能远程连接的解决方法
    这篇文章主要介绍“MYSQL不能远程连接的解决方法”,在日常操作中,相信很多人在MYSQL不能远程连接的解决方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MYSQL不能远...
    99+
    2022-10-18
  • win10 xboxlive连不上解决的方法
    这篇“win10 xboxlive连不上解决的方法”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“win10 xboxlive...
    99+
    2023-07-01
  • navicat连接sqlserver连不上的解决方法
    这篇文章给大家分享的是有关navicat连接sqlserver连不上的解决方法的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。Navicat无法连接SqlServer数据库怎么办?...
    99+
    2022-10-18
  • mysql不可以远程连接的解决方法
    这篇文章主要介绍mysql不可以远程连接的解决方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!mysql不可以远程连接的解决方法:1、打开命令提示符,登录mysql;2、执行【gr...
    99+
    2022-10-18
  • win2008远程桌面连接winxp连接不上的解决方法
    连接远程桌面在现在看来已经是十分必要的了,有些人常常出外上班或者出差,但是需要用到原本的电脑的时候就可以用这样的方法实现。用Window Server20008远程桌面连接一台Windows xp,连不上,用2008的机...
    99+
    2023-06-02
    XP 远程桌面 连接不上 解决 winxp 方法
  • mysql远程连接不上怎么解决
    这篇“mysql远程连接不上怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“mysq...
    99+
    2022-10-19
  • mysql远程连接不上如何解决
    当无法远程连接MySQL数据库时,可能有以下几个原因和解决方法:1. 防火墙问题:检查防火墙是否阻止了MySQL的远程连接。可以通过...
    99+
    2023-08-26
    mysql
  • 云服务器远程连接不上的解决方法
    1. 检查网络连接 首先,确保你的本地网络连接正常。可以尝试访问其他网站或使用其他网络设备进行连接,以确定问题是否出在你的网络上。 2. 检查云服务器状态 确认你的云服务器是否处于正常运行状态。可以登录到云服务提供商的管理控制台,查看服务...
    99+
    2023-10-28
    解决方法 连接不上 服务器
  • php连不上数据库的解决方法
    这篇文章将为大家详细讲解有关php连不上数据库的解决方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。php连不上数据库是因为PHP7已经抛弃了connect方法所以无法连接数据库,其解决办法就是使用my...
    99+
    2023-06-14
  • 解决Xshell连不上virtualBox虚拟机的解决方法
    首先说明virtualBox虚拟机的网络设置模式:NAT+Host-Only模式 选择该模式既能保证虚拟机连外网,也能保证本机电脑连接虚拟机。 网络1:NAT模式 网络2:Hos...
    99+
    2022-11-12
  • redis远程连接不上的解决办法
    目录问题描述:如图所示:解决步骤:步骤一:注释掉redis.window.conf文件中的bind属性设置。步骤二:把protected-mode属性设置no问题描述: redis远...
    99+
    2022-11-13
  • win10连不网上有感叹的解决方法
    win10系统软件是目前利用率十分高的电脑操作系统了但是许多客户在这里上边应用的过程中都遇上了连不上网发生感叹号的状况,今日就给大家产生了win10连不网上感叹解决方法,一起看一下win10连不网上有感叹的解决方法吧。win10连不网上有感...
    99+
    2023-07-10
  • XFTP连不上阿里云ECS的解决方法
    如果您正在使用XFTP连接阿里云ECS服务器,但是连接失败,那么这篇文章就是您需要的。本文将详细阐述XFTP连不上阿里云ECS的具体原因和解决方法。 问题描述:XFTP是Windows平台上的一个文件传输工具,支持FTP、FTPS、SFT...
    99+
    2023-11-04
    阿里 解决方法 连不上
  • 无线网络连接不上的解决方法
    无线网络连接不上的几种故障分析 无线网络连接不上该怎么办,解决无线网络连接不上的几种方法。 无线网络,特别是无线局域网给我们的生活带来了极大的方便,提供无处不在、高带宽的网络服务,但是,由于无线信道特有的性质,使得无线网...
    99+
    2023-05-26
    无线网络连接 无线网络连接不上 无线网络 解决 方法
  • win7重装后连不上WiFi的解决方法
    重新安装系统后,许多朋友的计算机无法连接到WiFi网络。这是因为计算机缺少网卡驱动程序。如果您在win7重装后无法连接WiFi,可参考以下图文教程重新安装或更新无线网卡驱动程序。快来看看吧。1、使用其他电脑上的浏览器搜索驱动精灵,进入官网下...
    99+
    2023-07-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作