如何保持mysql连接活在node.js

How to keep mysql connections alive in node.js?

本文关键字:node js 连接 何保持 mysql      更新时间:2023-09-26

我在Node JS中使用mysql连接池。经过一段空闲时间后,连接将过期,下次执行查询时,需要创建一个新连接。这可能导致几秒钟的延迟。不能接受的!

我想实现keepalive功能,以定期轮询数据库,并确保连接到后端一致的健康。我正在寻找其他尝试过相同方法的人的输入,或对我的方法的反馈。

const mysql = require('mysql');
const pool = createConnectionPool();
setInterval(keepalive, 180000); // 30 mins
function keepalive() {
  pool._freeConnections.forEach((connection) => pool.acquireConnection(connection,function () {
    connection.query('SELECT 1 + 1 AS solution', function (err) {
      if (err) {
        console.log(err.code); // 'ER_BAD_DB_ERROR'
      }
      console.log('Keepalive RDS connection pool using connection id', connection.threadId);
    })
  }));
}

这个keepalive在一定程度上是成功的:
-一旦连接打开,它将保持打开状态
-连接永远不会超时
-如果连接丢失,它会在下一个间隔

重新创建。

这个keepalive是不理想的:
mysql连接池是懒惰的,只在需要的时候创建和恢复连接。有了这个keepalive,池就不再懒惰了。一旦连接打开,keepalive将使其保持打开状态。池不再根据流量扩展。
-我不相信我通过自由连接列表迭代和执行查询的方法将是一个明智的方法。当keepalive正在使用相同的连接时,应用程序是否可能从池中检出相同的连接?

另一种可能的方法是放弃应用程序中的保持连接功能,并依赖心跳流量来保持最小的连接存活。

是否有人尝试实现keepalive功能,使用提供此功能的包或工具,或者最终使用不同的方法?

如果使用池连接,您是否尝试过这个

const pool = mysql.createPool({...});
function keepAlive() { 
  pool.getConnection(function(err, connection){
    if(err) { console.error('mysql keepAlive err', err); return; }
    console.log('ping db')
    connection.ping();     // this is what you want
    connection.release();
  });
}
setInterval(keepAlive, 60000); // ping to DB every minute

我没有使用pool,这段代码可以工作

function pingdb() {
  var sql_keep = `SELECT 1 + 1 AS solution`; 
  con.query(sql_keep, function (err, result) {
    if (err) throw err;
    console.log("Ping DB");
  });
}
setInterval(pingdb, 40000);