Caused by: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

Caused by: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure具体错误信息Causedby:com.mysql.jdbc.exceptions.jdbc4.CommunicationsException:CommunicationslinkfailureThelastpacketsuccessfullyreceivedfromtheserverwas1,548,635,756,564millisecondsago….

大家好,又见面了,我是你们的朋友全栈君。

具体错误信息

Caused by: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

The last packet successfully received from the server was 1,548,635,756,564 milliseconds ago.  The last packet sent successfully to the server was 0 milliseconds ago.


1、一般是由于连接的Ip地址、用户名、密码有误

Caused by: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

 

2、 特殊的情况

2.1、在JDBC URL中使用autoReconnect属性,实际测试时使用了autoReconnect=true&failOverReadOnly=false,网上所说的只对mysql 4之前的版本有效。

2.2、修改MySQL的参数,wait_timeout最大为31536000即1年,在my.cnf中加入:

[mysqld]

wait_timeout=31536000

interactive_timeout=31536000

重启生效,需要同时修改这两个参数


两种解决异常:“The last packet sent successfully to the server was 0 milliseconds ago. ”的办法

原因:由于数据库回收了连接,而系统的缓冲池不知道,继续使用被回收的连接所致的。

           第一种解决办法

         将mysql回收空闲连接的时间变长,mysql默认是8小时,可以在mysql目录下的my.ini中增加下面配置,将时间改为1天。

          [mysqld]

          wait_timeout=86400


           第二种解决办法

          可以通过配置,让缓冲池去测试连接是否被回收,如果被回收,则不继续使用,以dbcp为例

知识点:

          #SQL查询,用来验证从连接池取出的连接
          dbcp.validationQuery=SELECT 1
          #指明连接是否被空闲连接回收器(如果有)进行检验,如果检测失败,则连接将被从池中去除
          dbcp.testWhileIdle=true
          #在空闲连接回收器线程运行期间休眠的时间值,以毫秒为单位,一般比minEvictableIdleTimeMillis小
          dbcp.timeBetweenEvictionRunsMillis=300000
          #在每次空闲连接回收器线程(如果有)运行时检查的连接数量,最好和maxActive一致
         dbcp.numTestsPerEvictionRun=50
          #连接池中连接,在时间段内一直空闲,被逐出连接池的时间(1000*60*60),以毫秒为单位
          dbcp.minEvictableIdleTimeMillis=3600000
————————————————————————————-
<!– dataSourceNew start–>

    <bean id=”dataSourceNew” class=”org.apache.commons.dbcp.BasicDataSource”>
    <!– 设置JDBC驱动名称 –>
    <property name=”driverClassName” value=”${jdbc.driver}” />
    <!– 设置JDBC连接URL –>
    <property name=”url” value=”${jdbc.url.new}” />
    <!– 设置数据库用户名 –>
    <property name=”username” value=”${jdbc.username.new}” />
    <!– 设置数据库密码 –>
    <property name=”password” value=”${jdbc.password.new}” />
    <!– 设置连接池初始值 –>
    <property name=”initialSize” value=”5″ />
    <!– 设置连接池最大值 –>
    <property name=”maxActive” value=”8″ />
    <!– 设置连接池最小空闲值 –>
    <property name=”minIdle” value=”5″ />
    <!– 设置连接池最大空闲值 –>
    <property name=”maxIdle” value=”5″ />

        <property name=”validationQuery”>

        <value>SELECT 1</value>

        </property>

        <property name=”testWhileIdle”>

        <value>true</value>

        </property>

        <property name=”timeBetweenEvictionRunsMillis”>

        <value>300000</value>

        </property>

        <property name=”numTestsPerEvictionRun”>

        <value>8</value>

        </property>

        <property name=”minEvictableIdleTimeMillis”>

        <value>3600000</value>

        </property>

</bean>
————————————————————————————-

您的支持是我分享经验的动力

Caused by: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/152257.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 3DCNN参数解析:2013-PAMI-3DCNN for Human Action Recognition「建议收藏」

    3DCNN参数解析:2013-PAMI-3DCNN for Human Action Recognition「建议收藏」3DCNN参数解析:2013-PAMI-3DCNNforHumanActionRecognition参数分析Input:7@60×\times×40,7帧,图片大小60×\times×40hardwired:H1产生5通道信息,分别是gray,gradient-x,gradient-y,optflow-x,optflow-y。前三个对于每一张图片都计算得…

    2022年6月11日
    41
  • windows下thrift的使用(C++)

    windows下thrift的使用(C++)

    2021年11月19日
    53
  • Django(2)python虚拟环境virtualenvwrapper

    Django(2)python虚拟环境virtualenvwrapperpython虚拟环境虚拟环境(virtualenvironment),它是一个虚拟化,从电脑独立开辟出来的环境。通俗的来讲,虚拟环境就是借助虚拟机来把一部分内容独立出来,我们把这部分独立出来的东西

    2022年7月31日
    6
  • android 载入svg动画,Android 加载SVG动画[通俗易懂]

    android 载入svg动画,Android 加载SVG动画[通俗易懂]Android加载SVG动画SVG可以说是目前比较流行的图片格式,使用领域也十分广泛,例如:web前端页面,Androidios等移动应用。都可以使用SVG的图片格式。今天就要和大家谈一谈SVG在Android中的应用,SVG的引入其实在我之前的文章里已经有谈到。其实这个文章就是Android加载SVG的原理。文章地址点击进入(Path的高级用法)。还有一篇是谈到…

    2025年7月31日
    0
  • 从头开始建网站(三)DNS

    从头开始建网站(三)DNS

    2022年1月2日
    48
  • potplayer软件安装与常用配置

    potplayer软件安装与常用配置potplayer软件安装与常用配置1安装potplayer是一款十分好用的视频播放器,可以播放很多格式的视频,自定义皮肤,任意倍速,截取视频片段,还可以播放直播源(比如中国的CCTV以及各大卫视)…potplayer网址下载安装即可,最后如果显示要安装插件的话,去掉勾选即可2使用设置无边框:首先打开设置界面(快捷键F5),勾选如下两项设置打开视频时,默认居中显示,非全屏:首先打开设置界面(快捷键F5),进行如下两项设置进度条缩略图:首先打开设置界面(快捷键F5

    2022年5月11日
    92

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号