node环境下使用MYSQL数据库池断线后无法连接的解决办法

1. 使用环境说明

    1.1 node 环境 5.0以上

    1.2 依赖库为: generic-pool(数据库连接池)  mysql(数据库连接库)

 

2. 原因说明: 由于generic-pool仅限于管理连接,对于连接状态是不管理的,我们需要在进行调用数据库连接的时候 进行状态判断,如果是断开连接的错误 则释放这个连接,那么再次调用的时候就可以重新创建一个新的连接,从而达到重连数据库的目的。

 

3.代码说明

var _poolModule = require('generic-pool');
var CONNECTIOMERROR = ["PROTOCOL_ENQUEUE_AFTER_FATAL_ERROR", "ECONNREFUSED"];

/*
 * Create mysql connection pool.
 */
var createMysqlPool = function () {

    return _poolModule.Pool({
        name: 'mysql',
        create: function (callback) {

            var mysql = require('mysql');
            var client = mysql.createConnection({
                host: 'localhost',
                user: 'root',
                password: '123456',
                database: 'testdb',
                port: 3306
            });

            callback(null, client);
        },
        destroy: function (client) {
            client.end();
        },
        max: 10,
        idleTimeoutMillis: 30000,
        log: false
    });
};

var poolRead = createMysqlPool();

//定时查询数据库 模拟真实情况
setInterval(() => {

    poolRead.acquire(function (err, client) {

        if (!!err) {
            console.error('[sqlqueryErr] ' + err.stack);
            return;
        }

        var sql = "select * from user limit 1";
        client.query(sql, [], function (err, res) {

            //在连接这边进行判断 如果该连接失效则释放 直到连接正常 从而达到重连的目的
            if (!!err && CONNECTIOMERROR.indexOf(err.code) != -1) {

                poolRead.destroy(client);
            } else {

                poolRead.release(client);
            }

            if (err) {
                console.error(err.code);
            }
        });
    });

}, 1000);

// 在mysql库中认为连接断开是个致命的错误会直接抛出错误中断运行,这里需要进行捕获错误让程序运行下去
process.on('uncaughtException', function (err) {
    console.error(' Caught exception: ' + err.stack);
});

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值