0

这里的第一个问题,所以请善待;)

我正在配置 Node.js 服务器以连接到 Modulus.io node.js 托管中的 MongoDB 数据库(非常好的东西,值得一试),但我似乎无法正确建立连接。根据入门指南,我得到一个连接 uri,格式如下:

mongodb://user:pass@mongo.onmodulus.net:27017/3xam913

但这似乎不适用于我试图移植到服务器的代码结构(让它在本地运行),因为Server 类参数结构只有主机和端口要定义......

这是我试图适应连接的代码:

// server setup
var mongo = require('mongodb'),
    mdbServer = mongo.Server,
    mdbDb = mongo.Db,
    mdbObjectID = mongo.ObjectID;

// open a connection to the mongoDB server
var mdbserver = new mdbServer('localhost', 27017, {auto_reconnect: true});

// request or create a database called "spots03"
var db = new mdbDb('spots03', mdbserver, {safe: true});

// global var that will hold the spots collection
var spotsCol = null;

// open the database
db.open(function(err, db) {
    if(!err) {
        // if all cool
        console.log("Database connection successful");

        // open (get/create) a collection named spotsCollection, and if 200, 
        // point it to the global spotsCol
        db.createCollection(
            'spotsCollection',
            {safe: false},  // if col exists, get the existing one
            function(err, collection) {spotsCol = collection;}
        );
    }
});

任何帮助将不胜感激,谢谢!

4

2 回答 2

3

看起来有几件事:

  1. 连接 URL 应该是 mongo.onmodulus.net

    var mdbserver = new mdbServer('mongo.onmodulus.net', 27017, {auto_reconnect: true});

  2. rounce 是正确的,数据库名称是由 Modulus 自动生成的。

    var db = new mdbDb('3xam913', mdbserver, {safe: true});

  3. 模数数据库将需要身份验证。在调用 createCollection 之前,您必须调用 auth 并将在项目仪表板上设置的用户凭据传递给它。

我是一名 Modulus 开发人员,我知道数据库名称并不理想。

编辑:这是一个工作示例的完整来源。它记录每个 HTTP 请求,然后将所有请求发送回用户。

var express = require('express'),
      mongo = require('mongodb'),
     Server = mongo.Server,
         Db = mongo.Db;

var app = express();

var server = new Server('mongo.onmodulus.net', 27017, { auto_reconnect: true });
var client = new Db('piri3niR', server, { w: 0 });
client.open(function(err, result) {
  client.authenticate('MyUser', 'MyPass', function(err, result) {
    if(!err) {
      console.log('Mongo Authenticated. Starting Server on port ' + (process.env.PORT || 8080));
      app.listen(process.env.PORT || 8080);
    }
    else {
      console.log(err);
    }
  });
});

app.get('/*', function(req, res) {
  client.collection('hits', function(err, collection) {
    collection.save({ hit: req.url });

    // Wait a second then print all hits.
    setTimeout(function() {
      collection.find(function(err, cursor) {
        cursor.toArray(function(err, results) {
          res.send(results);
        });
      });
    }, 1000)
  });
});
于 2012-12-29T23:48:40.533 回答
1

可能是错误的数据库名称?

来自主题“3xam913”的 MongoDB文档是您的数据库名称,而不是“spots03”。

var db = new mdbDb('3xam913', mdbserver, {safe: true});
于 2012-12-29T02:59:46.320 回答