Sails.js,MongoDb:尝试连接时超时;可能使用连接池?
问题描述:
帆服务器:Sails.js,MongoDb:尝试连接时超时;可能使用连接池?
- 的Windows 10的64位
- Sails.js 1.0.0-36
- Node.js的6.10.2
的MongoDB服务器:
- Virtualbox上的Centos 7,仅主机联网
- Mongodb 3.4.4,听完所有接口,没有权威性配置
我可以成功地解除帆,连接数据存储,并使用这些模型没有任何问题。
然而,本次测试将导致在超时:
let mongo = require('mongodb');
let uri = 'mongodb://' + process.env.MONGO_SERVER + ':' + process.env.MONGO_PORT + '/sails';
mongo.MongoClient.connect(uri, function(err, db) {
if(err){
return res.serverError(err);
}
return res.json("open");
});
{ MongoError: failed to connect to server [192.168.99.2:27027] on first connect [MongoError: connect ETIMEDOUT 192.168.99.2:27027]
at Pool.<anonymous> (....\node_modules\mongodb-core\lib\topologies\server.js:329:35)
at emitOne (events.js:96:13)
at Pool.emit (events.js:188:7)
at Connection.<anonymous> (....\node_modules\mongodb-core\lib\connection\pool.js:280:12)
at Connection.g (events.js:291:16)
at emitTwo (events.js:106:13)
at Connection.emit (events.js:191:7)
at Socket.<anonymous> (....\node_modules\mongodb-core\lib\connection\connection.js:187:49)
at Socket.g (events.js:291:16)
at emitOne (events.js:96:13)
at Socket.emit (events.js:188:7)
at emitErrorNT (net.js:1281:8)
at _combinedTickCallback (internal/process/next_tick.js:80:11)
at process._tickDomainCallback (internal/process/next_tick.js:128:9)
name: 'MongoError',
message: 'failed to connect to server [192.168.99.2:27027] on first connect [MongoError: connect ETIMEDOUT 192.168.99.2:27027]' }
我使用的数据存储上使用完全相同的服务器信息。
那么这里可能会出现什么问题?
同样重要的是:是否可以使用全局Sails连接池而不是创建新连接?怎么样?我搜索了文档,但找不到具体的参考文献。
答
代码是错误的 - 使用端口27027,而应该是27017
数据存储的连接工作,因为正确的后备我没有”的t notice
答
试试这个
var MongoClient = require('mongodb').MongoClient;
MongoClient.connect("mongodb://localhost:27017/test", function(err, db) {
test.equal(null, err);
test.ok(db != null);
});
编号:here
'err'绝对不是'null' ---这就是我得到的错误,不需要以不同的方式测试它,谢谢。 – noderman