节点js连接到mongo db

时间:2014-02-16 13:55:54

标签: node.js mongodb appfog

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类错误,但是所有这些概念在我看来都是我的头脑。

谢谢!

1 个答案:

答案 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){