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

作者:北漂燕郊杨哥 时间:2024-01-15 11:47:34 

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.进入后是这样的:

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

4.输入MySQL语句

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

出现:

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

再输入flush privileges;

出现:

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

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

参考文章:

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

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

来源:https://blog.csdn.net/itopit/article/details/130620406

标签:Nodejs,mysql,报错
0
投稿

猜你喜欢

  • Python filter过滤器原理及实例应用

    2021-03-20 13:11:13
  • Python爬虫学习之获取指定网页源码

    2023-11-06 02:29:15
  • 记录微信小程序 height: calc(xx - xx);无效问题

    2024-05-02 16:27:16
  • 如何利用Pytorch计算三角函数

    2021-01-27 11:35:47
  • JS数组方法concat()用法实例分析

    2024-04-29 14:08:20
  • 微信小程序与axios组成网络层封装过程详解

    2024-04-19 10:01:38
  • Python使用PyAudio制作录音工具的实现代码

    2023-09-07 22:36:46
  • 探讨:如何查看和获取SQL Server实例名

    2024-01-18 03:47:42
  • document.all还是document.getElementsByName?

    2024-04-18 09:34:28
  • 使用Requests库来进行爬虫的方式

    2022-07-20 18:00:33
  • Web页面空间利用率的思考

    2009-07-03 12:45:00
  • Python程序员开发中常犯的10个错误

    2023-12-14 04:56:32
  • python字符串常用方法及文件简单读写的操作方法

    2023-11-24 10:20:04
  • SQL2005查看死锁存储过程sp_who_lock

    2024-01-12 20:34:13
  • python生成遍历暴力破解密码的方法

    2021-07-02 21:28:54
  • SQLserver中字符串查找功能patindex和charindex的区别

    2012-06-06 20:20:42
  • mysql limit分页优化方法分享

    2024-01-26 22:03:40
  • python数据化运营的重要意义

    2021-05-05 21:02:27
  • python 实现学生信息管理系统的示例

    2021-05-01 01:37:24
  • Python监控服务器实用工具psutil使用解析

    2021-10-14 03:16:24
  • asp之家 网络编程 m.aspxhome.com