我有连接到 db 并管理连接的 database.js 文件我导出连接并在我的应用程序中重用它
var mysql = require('mysql');
pool = mysql.createPool({
host: cfg.mysql.host,
user: cfg.mysql.user,
password: cfg.mysql.pass,
database: cfg.mysql.db,
port: cfg.mysql.port
});
function handleDisconnect() {
pool.getConnection(function(err, cnt) {
module.exports.connection = cnt;
});
pool.on('error', function (err) {
console.log(err);
});
};
handleDisconnect();
process.on('uncaughtException', function (err) {
console.error(err.code);
if(err.code === "PROTOCOL_CONNECTION_LOST")
handleDisconnect();
console.log("Node NOT Exiting...");
});
应用程序.js
var db = require('./database');
app.get('/test', function(req, res) {
db.connection.query('SELECT * from table', function(err, result) {
console.log(result);
});
}
这工作正常。我的问题是mysql服务器断开连接时。我通过调用 handleDisconnect() 函数来获取新连接来处理此错误。但是,当我导航到浏览器 /test 时,我的 app.js 中的连接未定义
TypeError: Cannot call method 'query' of undefined
想法?