解决nodejs mysql Error: Connection lost The server closed the connection

node mysql连接出现Error: Connection lost The server closed the connection,原因是mysql连接建立后有一个保活时间,这个wait_time实测大概是在大几个小时左右,时间超过mysql就会自动关闭连接,所以方法就是检测到出现Error: Connection lost The server closed the connection时自动重连就行

let connection ='';
mysql = require('mysql');
function handleDisconnection() {
    connection = mysql.createConnection({
        host: 'localhost',
        user: 'root',  //用户名
        password: '',   //密码
        database: '',
        port: '3306'     //端口号
    })
    connection.connect(function (err) {
        if (err) {
            setTimeout('handleDisconnection()', 2000);
        }
    });

    connection.on('error', function (err) {
        logger.error('db error', err);
        if (err.code === 'PROTOCOL_CONNECTION_LOST') {
            logger.error('db error执行重连:' + err.message);
            handleDisconnection();
        } else {
            throw err;
        }
    });
}
handleDisconnection();

这里声明一个全局变量connection,然后在handleDisconnection()里创建连接赋给connection,就可以在下面使用了
例如:

function getList(callback) {
    connection.query('select * from xxx', (err, data, fields) => {
        return callback(err, data, fields)
    })
}

下面是截图
在这里插入图片描述
修改后的效果
在这里插入图片描述
哈哈,大佬看见不足之处还望指正

参考解决nodejs mysql Error

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值