關(guān)于Node.js 鏈接mysql超時(shí)處理(默認(rèn)8小時(shí))

備注:這是在pm2配置node環(huán)境下,超過(guò)8小時(shí)mysql自動(dòng)關(guān)閉的情況下出現(xiàn)的解決方法:
1、封裝mysql.js

var mysql = require('mysql');
var connection = {
    host: '',//主機(jī)名
    user: '',//用戶名
    password: '',//密碼
    database: ''//數(shù)據(jù)庫(kù)
}


// 用于保存數(shù)據(jù)連接實(shí)例
var db = null;

var pingInterval;

// 如果數(shù)據(jù)連接出錯(cuò),則重新連接
function handleError(err) {
    logger.info(err.stack || err);
    connect();
}

// 建立數(shù)據(jù)庫(kù)連接
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);

    // 每個(gè)小時(shí)ping一次數(shù)據(jù)庫(kù),保持?jǐn)?shù)據(jù)庫(kù)連接狀態(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的金豆之路

主要領(lǐng)域:前端開(kāi)發(fā)

我的微信:maomin9761

微信公眾號(hào):前端歷劫之路