Two ways of solving
1. You can configure MySQL connection pool
var mysql = require(‘mysql‘);var pool = mysql.createPool({ host: ‘localhost‘, user: ‘nodejs‘, password: ‘nodejs‘, database: ‘nodejs‘, port: 3306});var selectSQL = ‘select * from t_user limit 10‘;pool.getConnection(function (err, conn) { if (err) console.log("POOL ==> " + err); conn.query(selectSQL,function(err,rows){ if (err) console.log(err); console.log("SELECT ==> "); for (var i in rows) { console.log(rows[i]); } conn.release(); });});
2, you can use the disconnection method to solve
var mysql = require(‘mysql‘);var conn;function handleError () { conn = mysql.createConnection({ host: ‘localhost‘, user: ‘nodejs‘, password: ‘nodejs‘, database: ‘nodejs‘, port: 3306 }); //连接错误,2秒重试 conn.connect(function (err) { if (err) { console.log(‘error when connecting to db:‘, err); setTimeout(handleError , 2000); } }); conn.on(‘error‘, function (err) { console.log(‘db error‘, err); // 如果是连接断开,自动重新连接 if (err.code === ‘PROTOCOL_CONNECTION_LOST‘) { handleError(); } else { throw err; } });}handleError();
Nodejs using MySQL connection pool, wire break reconnection