我的 Node.js 代码如下
CODE1:下面
var http=require('http');
var MySQL = require('mysql');
mysql = MySQL.createConnection(...)
http.createServer(function(req, res){
// the query will take several seconds
mysql.query("SELECT SLEEP(1)", function....)
});
http.listen(...);
问题是当我刷新页面太快时服务器会崩溃。我认为是 node-mysql 模块的问题,它处理队列中的查询。所以我尝试创建一个连接池。
CODE2: 下面
....
var pool = require('generic-pool');
var mp = pool.Pool({
...
create: function(cb){
client = MySQL.createConnection(...);
cb(null, client)
},
max: 10, // up to 10 connection
min: 2,
...
});
....
mp.acquire(function(err, mysql){
// the query will take several seconds
mysql.query("SELECT SLEEP(1)", function....)
mp.release(mysql);
});
....
但问题依然存在,为什么呢?我怎样才能解决这个问题。
编辑:我以 100 个并发启动 100 个请求,预计需要 10 秒。但这需要20秒。为什么?池是否只支持最多 5 个连接?