データベースに接続して接続を管理する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...");
});
app.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
考え?