db beginner试图让mongodb和nodejs在云上互相交谈。
我正在app-fog上主持一个应用程序,但即使我尝试做最基本的查询,我也会失败。这是推送到云端的app.js文件的内容。我相信我已经安装了所有必要的依赖项(npm install mongodb&& express&& bson&&" shrinkwarp)但是我可能在某个地方失败了,尽管我经历了整个过程两次。
var port = (process.env.VMC_APP_PORT || 3000);
var host = (process.env.VCAP_APP_HOST || 'localhost');
var http = require('http');
if(process.env.VCAP_SERVICES){
var env = JSON.parse(process.env.VCAP_SERVICES);
var mongo = env['mongodb-1.8'][0]['credentials'];
} else {
var mongo = {
"hostname":"localhost",
"port":3000,
"username":"",
"password":"",
"name":"",
"db":"db"
}
}
var generate_mongo_url = function(obj){
obj.hostname = (obj.hostname || 'localhost');
obj.port = (obj.port || 3000);
obj.db = (obj.db || 'test');
if(obj.username && obj.password){
return "mongodb://" + obj.username + ":" + obj.password + "@" + obj.hostname + ":" + obj.port + "/" + obj.db;
}else{
return "mongodb://" + obj.hostname + ":" + obj.port + "/" + obj.db;
}
}
var mongourl = generate_mongo_url(mongo);
var record_visit = function(req, res){
/* Connect to the DB and auth */
require('mongodb').connect(mongourl, function(err, conn){
if(err){
console.log(">>",err);
}
conn.collection('ips', function(err, coll){
/* Simple object to insert: ip address and date */
object_to_insert = { 'ip': req.connection.remoteAddress, 'ts': new Date() };
/* Insert the object then print in response */
/* Note the _id has been created */
coll.insert( object_to_insert, {safe:true}, function(err){
res.writeHead(200, {'Content-Type': 'text/plain'});
res.write(JSON.stringify(object_to_insert));
res.end('\n');
});
});
});
}
http.createServer(function(res,req){
record_visit(req,res);
require('mongodb').connect(mongourl,function(err,conn){
console.log(conn+"\n\n");
});
console.log('Hello from us.\n');
})。listen(process.env.VCAP_APP_PORT || 3000);
现在我似乎总是得到这个错误:
node_modules/mongodb/lib/mongodb/mongo_client.js:378
throw err
^
TypeError: Cannot call method 'collection' of null
问题似乎不仅仅是收集问题,而是主要是它的父版conn
,我试图将其打印出来但却没有成功。 (我怀疑它本身是未定义的。)
我知道这可能是一个简单的RTFM类错误,但是所有这些概念在我看来都是我的头脑。
谢谢!
答案 0 :(得分:0)
如果您记录err
的{{1}}:
connect
BTW:在继续使用回调的第二个参数之前,你总是要检查require('mongodb').connect(mongourl, function(err, conn){
if( err ) {
console.log( err ); // <-- here
...
}
conn.collection('ips', function(err, coll){
。