繁体   English   中英

使用Mongoskin和MongoHQ和Node.js部署到Heroku时遇到问题

[英]Trouble deploying to Heroku using Mongoskin and MongoHQ with Nodejs

我目前正在构建一个使用mongoskin的node / express.js应用程序。 我最近将我的应用程序部署到了Heroku,并且由于将mongohq与我的应用程序结合使用而感到头疼。

这是我与节点app.js一起运行的app.js文件

var express = require("express");
var app = express();
decks = require('./routes/decks');
app.get('/decks', decks.findAll);

我的package.json:

{
    "name": "blah blah",
    "description": "Why are there so my blah blah",
    "version": "0.0.1",
    "private": true,
    "dependencies": {
        "express": "3.x",
        "mongodb": "1.1.8",
        "socket.io": "0.9.10"
    },
    "engines": {
        "node": "0.8.4",
        "npm": "1.1.49"
    }
}

阅读了有关Heroku的指南后,我尝试重新构建decks.js并像这样使用mongoskin。

var mongo = require('mongoskin'); 
var mongoUri = process.env.MONGOHQ_URL;
var db = mongo.db(mongoUri);

exports.findById = function(req, res) {
     var id = req.params.id;
     console.log('Retrieving deck: ' + id);
     db.collection('decks', function(err, collection) {
         collection.findOne({'_id':new BSON.ObjectID(id)}, function(err, item) {
             res.send(item);
         });
     });
 };

但是我一直在得到错误:

 Please ensure that you set the default write concern for the database by setting    =
=   one of the options                                                                 =
=                                                                                      =
=     w: (value of > -1 or the string 'majority'), where < 1 means                     =
=        no write acknowlegement                                                       =
=     journal: true/false, wait for flush to journal before acknowlegement             =
=     fsync: true/false, wait for flush to file system before acknowlegement           =
=                                                                                      =
=  For backward compatibility safe is still supported and                              =
=   allows values of [true | false | {j:true} | {w:n, wtimeout:n} | {fsync:true}]      =
=   the default value is false which means the driver receives does not                =
=   return the information of the success/error of the insert/update/remove            =
=                                                                                      =
=   ex: new Db(new Server('localhost', 27017), {safe:false})                           =
=                                                                                      =
=   http://www.mongodb.org/display/DOCS/getLastError+Command                           =
=                                                                                      =
=  The default of no acknowlegement will change in the very near future                =
=                                                                                      =
=  This message will disappear when the default safe is set on the driver Db           =
========================================================================================

我读了很多教程,但是我无法使数据库正常工作! 请任何帮助,您将不胜感激。

您的Db对象正在使用不建议使用的设置:“安全”。

如果将“ w”选项设置为所需的写关注点,则该错误应消失。

这是用于实例化该Db对象的文档的链接。

http://mongodb.github.io/node-mongodb-native/api-generation/db.html

...

哦,您可以尝试将uri变量更新为process.env.MONGOHQ_URL:P

社长说的对

修改此行:

var db = mongo.db(mongoUri);

对此:

var db = mongo.db(mongoUri, {w:1});

这将使您在对数据库执行操作时写确认,并使错误消失

有关写问题的更多信息,请查看此链接

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM