Nodejs 连接 mysql时报Error: Cannot enqueue Query after fatal error错误的处理办法

 更新时间:2023年05月12日 10:05:24   作者:北漂燕郊杨哥  
这篇文章主要介绍了Nodejs 连接 mysql时报Error: Cannot enqueue Query after fatal error错误的处理办法,需要的朋友可以参考下

Nodejs 连接 mysql时报Error: Cannot enqueue Query after fatal error错误的处理办法

一、nodejs连接mysql?

npm install mysql --save

创建连接代码 db.js

//导入mysql连接包
const mysql = require('mysql');
let dbconfig ={
    host: 'db_host',
    user: 'db_user',
    password: 'db_pass',
    database: 'db_name',
    debug: true
};
function handleDisconnection() {
    db = mysql.createConnection(dbconfig);
    db.connect(function (err) {
        if (err) {
            console.log('db connect error:' + err.message + "2秒后重连");
            setTimeout(handleDisconnection, 2000);
        }
    });
    db.on('error', function (err) {
        console.log(err);
        if (err.code === 'PROTOCOL_CONNECTION_LOST') {
            console.log('db error执行重连:' + err.message);
            handleDisconnection();
        } else {
            throw err;
        }
    });
    db.querySync = function(sql) {
        return new Promise(function(resolve, reject) {
            db.query(sql, function(error, results, fields) {
                if(error) reject(error);
                else resolve({results, fields})
            })
        })
    };
    return db;
}
//创建连接conn
exports.db = handleDisconnection();

二、Nodejs 连接 mysql时报错 Error: Cannot enqueue Query after fatal error

1.原配置参数

let dbconfig ={
    host: 'db_host',
    user: 'db_user',
    password: 'db_pass',
    database: 'db_name',
    debug: true
};

只要加上useConnectionPooling: true参数就可以了

2.新配置参数

let dbconfig ={
    host: 'db_host',
    user: 'db_user',
    password: 'db_pass',
    database: 'db_name',
    useConnectionPooling: true,
    debug: true
};

补充:Node.js连接MySQL数据库报错

解决Node.js第一次连接MySQL数据库时出现[SELECT ERROR] - ER_NOT_SUPPORTED_AUTH_MODE: Client does not support authentication protocol requested by server; consider upgrading MySQL client的错误。

报错原因:mysql8.0以上的加密方式,Node.js还不支持。

解决方法:

进入mysql(cmd管理员模式)

1.第一步:启动mysql服务,可以通过net start mysql命令实现

2.第二步:在命令行输入:mysql -u用户名 -p密码,回车;
-h表示服务器名,localhost表示本地,-hlocalhost 可不输入;
-u为数据库用户名,root是mysql默认用户名;
-p为密码,如果设置了密码,可直接在-p后链接输入,如:-p123456,用户没有设置密码,显示Enter password时,直接回车即可。)
例子:mysql -hlocalhost -uroot -p123456,包含了密码会直接进入

3.进入后是这样的:

4.输入MySQL语句

先输入alter user 'root'@'localhost' identified with mysql_native_password by '123456';

出现:

再输入flush privileges;

出现:

问题解决了,再次运行就不会报错了

参考文章:

https://blog.csdn.net/weixin_43042683/article/details/106779060

https://www.cnblogs.com/jing-tian/p/11688073.html 

到此这篇关于Nodejs 连接 mysql时报Error: Cannot enqueue Query after fatal error错误的处理办法的文章就介绍到这了,更多相关Nodejs 连接 mysql报错内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • nodejs实现日志读取、日志查找及日志刷新的方法分析

    nodejs实现日志读取、日志查找及日志刷新的方法分析

    这篇文章主要介绍了nodejs实现日志读取、日志查找及日志刷新的方法,涉及nodejs日期时间运算、转换及日志读写等相关操作技巧,需要的朋友可以参考下
    2019-05-05
  • Node.js爬虫如何获取天气和每日问候详解

    Node.js爬虫如何获取天气和每日问候详解

    这篇文章主要给大家介绍了关于Node.js爬虫如何获取天气和每日问候的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Node.js爬虫具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-08-08
  • node.js实现博客小爬虫的实例代码

    node.js实现博客小爬虫的实例代码

    这篇文章通过实例代码来给大家介绍如何利用node.js实现博客小爬虫,有需要的朋友们可以直接运用文中给出的实例代码来进行实践学习,感兴趣的朋友们下面来一起看看吧。
    2016-10-10
  • node.js中的fs.readFileSync方法使用说明

    node.js中的fs.readFileSync方法使用说明

    这篇文章主要介绍了node.js中的fs.readFileSync方法使用说明,本文介绍了fs.readFileSync的方法说明、语法、接收参数、使用实例和实现源码,需要的朋友可以参考下
    2014-12-12
  • mac下安装node.js的详细步骤

    mac下安装node.js的详细步骤

    Node.js本质上是一个JavaScript运行时环境,它提供了在服务器端运行JavaScript代码的能力,这篇文章主要给大家介绍了关于mac下安装node.js的详细步骤,需要的朋友可以参考下
    2023-10-10
  • node.js使用express-fileupload中间件实现文件上传

    node.js使用express-fileupload中间件实现文件上传

    本文使用express作为服务端,使用express-fileupload库提供的中间件函数来接受从客户端传来的图片,并将图片作为文件存储在服务端,感兴趣的可以了解一下
    2021-07-07
  • 基于NodeJS+MongoDB+AngularJS+Bootstrap开发书店案例分析

    基于NodeJS+MongoDB+AngularJS+Bootstrap开发书店案例分析

    这章的目的是为了把前面所学习的内容整合一下,这个示例完成一个简单图书管理模块,因为中间需要使用到Bootstrap这里先介绍Bootstrap
    2017-01-01
  • 基于node的cli工具开发使用详解

    基于node的cli工具开发使用详解

    这篇文章主要为大家介绍了基于node的cli工具开发使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • 使用node.js对音视频文件加密的实例代码

    使用node.js对音视频文件加密的实例代码

    本文通过实例代码给大家介绍了使用node.js对音视频文件加密的方法,非常不错,具有参考借鉴价值,需要的的朋友参考下吧
    2017-08-08
  • node.js中的path.extname方法使用说明

    node.js中的path.extname方法使用说明

    这篇文章主要介绍了node.js中的path.extname方法使用说明,本文介绍了path.extname的方法说明、语法、使用实例和实现源码,需要的朋友可以参考下
    2014-12-12

最新评论