配置mysql node js错误,发生致命错误后无法排队查询

时间:2019-02-26 14:44:42

标签: javascript node.js express

我在pm2上运行了一个应用程序nodejs。

我的应用程序有一个奇怪的行为,在运行了3 4或5天的一段时间内,我无法识别问题 尝试进行简单登录并需要与数据库连接的应用程序时,会发生以下错误:

致命错误后无法排队查询

我已尽一切可能尝试找出导致此问题的原因,但尚未发现数据库服务器的故障。

有人可以尝试提供帮助,也许这是导致与银行的连接错误的方式。

数据库连接配置db.js

const mysql = require('mysql');

const connection = mysql.createConnection({
    connectionLimit : 20,
    host     : '******',
    port     : 3306,
    user     : '******',
    password : '******',
    database : '******'
});

connection.connect(function(err) {
    if (err) {
        console.log('Conexão com banco ocorreu erro. ' + err + ' ' + err.code);
        return;
    }
    console.log('Conexão com banco ok!');
});

module.exports = connection;

使用我们的路线

var express = require('express');
var router = express.Router();

var usuarioController  = require('../controllers/usuario-controller');

router.get('/find/:id', usuarioController.findUsuario);

module.exports = router;

usuarioController

var db = require('../models/db');

var usuarioController = {


    findUsuario: function(req, res) {

        var codigoPessoa = req.params.id;

        var sql = "SELECT p.codigoPessoa As codigo, "+
                  "  p.nome AS nome "+
                  "  FROM tpessoa p, "+
                  "      tusuario u "+
                  "  WHERE p.codigoPessoa = u.codigoPessoa "+
                  "  AND u.codigoPessoa = " + codigoPessoa;

        db.query(sql, function (err, rows) {
            if (err) {

                var message = err.message;

                return res.status(500).send(message);

            } else {

                res.status(200).json(rows);
            }
        });
    },
};

module.exports = usuarioController;

错误

Error: Connection lost: The server closed the connection.
    at Protocol.end (/home/softaction/apps_nodejs/node_modules/mysql/lib/protocol/Protocol.js:112:13)
    at Socket.<anonymous> (/home/softaction/apps_nodejs/node_modules/mysql/lib/Connection.js:97:28)
    at Socket.<anonymous> (/home/softaction/apps_nodejs/node_modules/mysql/lib/Connection.js:502:10)
    at emitNone (events.js:111:20)
    at Socket.emit (events.js:208:7)
    at endReadableNT (_stream_readable.js:1064:12)
    at args.(anonymous function) (/opt/nvm/versions/node/v8.11.3/lib/node_modules/pm2/node_modules/event-loop-inspector/index.js:138:29)
    at _combinedTickCallback (internal/process/next_tick.js:138:11)
    at process._tickCallback (internal/process/next_tick.js:180:9)
Error: Cannot enqueue Query after fatal error.
    at Protocol._validateEnqueue (/home/softaction/apps_nodejs/node_modules/mysql/lib/protocol/Protocol.js:200:16)
    at Protocol._enqueue (/home/softaction/apps_nodejs/node_modules/mysql/lib/protocol/Protocol.js:138:13)
    at Connection.query (/home/softaction/apps_nodejs/node_modules/mysql/lib/Connection.js:200:25)
    at Strategy._verify (/home/softaction/apps_nodejs/security/autenticacao.js:66:16)
    at Strategy.authenticate (/home/softaction/apps_nodejs/node_modules/passport-local/lib/strategy.js:88:12)
    at attempt (/home/softaction/apps_nodejs/node_modules/passport/lib/middleware/authenticate.js:361:16)
    at authenticate (/home/softaction/apps_nodejs/node_modules/passport/lib/middleware/authenticate.js:362:7)

我的数据库连接配置文件位于项目的单独文件夹中。

示例:

-app
--models
---db.js
--controllers
---usuario-controller.js
--routes
---usuario-route.js

2 个答案:

答案 0 :(得分:0)

处理此问题的常用方法似乎是使用pool of connections

您可以看到基于与this post中相同问题的示例。那里的答案之一显示了一种覆盖query方法的方法,这样您就不必用getConnection / release重写每个调用。

您可以使用本地数据库对此进行测试:

  • 启动数据库
  • 启动服务器
  • 尝试登录(或查询某些内容的模拟路线)
  • 确保它有效
  • 杀死/重启数据库
  • 再次尝试路线
  • 确保您遇到相同的错误
  • 根据上面的链接实施解决方案
  • 再次测试并检查问题是否消失

答案 1 :(得分:0)

我遇到了同样的问题,找到了 this,对其进行了测试,结果奏效了。这是一个名为 serverless-mysql 的 NPM 模块。