关于nodejsmysql超时的问题,The server closed the connection

2017-07-15 16:12:29

wait_timeout 造成  Connection lost,The server closed the connection

在你不没有数据库操作的情况下,8小时后服务会挂点,因为你的数据库设置了超时时间。

解决方案:

  1. 做一个定时,在没短时间访问以下数据库,间隔小于八小时。


  2. function keepalive() {
      connection.query('select 1', [], function(err, result) {
        if(err) return console.log(err);
        // Successul keepalive
      });}setInterval(keepalive, 1000*60*5);

    2.用nodejs mysql的线程池去链接数据库,每当有链接挂掉,就会重新链接。


    = .({
      : ,
      : ,
      : ,
      : ,
      : });



  • 2019-09-28 08:00:30

    Java.io.tmpdir介绍

    System.getproperty(“java.io.tmpdir”)是获取操作系统缓存的临时目录,不同操作系统的缓存临时目录不一样,

  • 2019-09-28 08:36:43

    Ehcache配置持久化到硬盘,只存储到硬盘

    Ehcache默认配置的话 为了提高效率,所以有一部分缓存是在内存中,然后达到配置的内存对象总量,则才根据策略持久化到硬盘中,这里是有一个问题的,假如系统突然中断运行 那内存中的那些缓存,直接被释放掉了,不能持久化到硬盘;这种数据丢失,对于一般项目是不会有影响的,但是对于我们的爬虫系统,我们是用来判断重复Url的,所以数据不能丢失;

  • 2019-09-28 09:33:18

    put与putIfAbsent区别

    put在放入数据时,如果放入数据的key已经存在与Map中,最后放入的数据会覆盖之前存在的数据, 而putIfAbsent在放入数据时,如果存在重复的key,那么putIfAbsent不会放入值。