前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >关于Node.js 链接mysql超时处理(默认8小时)

关于Node.js 链接mysql超时处理(默认8小时)

作者头像
马克社区
发布2022-06-15 19:14:32
1K0
发布2022-06-15 19:14:32
举报
文章被收录于专栏:高端IT高端IT

备注:这是在pm2配置node环境下,超过8小时mysql自动关闭的情况下出现的解决方法: 1、封装mysql.js

代码语言:javascript
复制
var mysql = require('mysql');
var connection = {
    host: '',//主机名
    user: '',//用户名
    password: '',//密码
    database: ''//数据库
}


// 用于保存数据连接实例
var db = null;

var pingInterval;

// 如果数据连接出错,则重新连接
function handleError(err) {
    logger.info(err.stack || err);
    connect();
}

// 建立数据库连接
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一次数据库,保持数据库连接状态
    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引入以下代码就能用了

更多内容请见原文,原文转载自:https://blog.csdn.net/weixin_44519496/article/details/119836351

本文系转载,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文系转载前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档