關于Node.js 鏈接mysql超時處理(默認8小時)
備注:這是在pm2配置node環(huán)境下,超過8小時mysql自動關閉的情況下出現(xiàn)的解決方法:
1、封裝mysql.js
var mysql = require('mysql');
var connection = {
host: '',//主機名
user: '',//用戶名
password: '',//密碼
database: ''//數(shù)據庫
}
// 用于保存數(shù)據連接實例
var db = null;
var pingInterval;
// 如果數(shù)據連接出錯,則重新連接
function handleError(err) {
logger.info(err.stack || err);
connect();
}
// 建立數(shù)據庫連接
function connect() {
if (db !== null) {
db.destroy();
db = null;
}
db = mysql.createConnection(connection);
db.connect(function (err) {
if (err) {
logger.info("error when connecting to db,reConnecting after 2 seconds:", err);
setTimeout(connect, 2000);
}
});
db.on("error", handleError);
// 每個小時ping一次數(shù)據庫,保持數(shù)據庫連接狀態(tài)
clearInterval(pingInterval);
pingInterval = setInterval(() => {
console.log('ping...');
db.ping((err) => {
if (err) {
console.log('ping error: ' + JSON.stringify(err));
}
});
}, 3600000);
}
connect();
module.exports = db;
2、在server.js引入以下代碼就能用了
var connection = require('./mysql');
作者:Vam的金豆之路
主要領域:前端開發(fā)
我的微信:maomin9761
微信公眾號:前端歷劫之路