从node.js连接到mongodb时出现ECONNREFUSED错误

我知道我正在做一些非常愚蠢和无聊,但我希望有人可以帮助我在mac上从node.js建立一个基本的数据库连接到mongodb。

我已经使用自制软件安装了mongodb,似乎工作得很好。我已经启动服务器(mongod)作为本地登录用户,并打开了一个第二个终端,并确认我可以使用mongo连接到它。当我运行mongo时,我收到消息“连接到:localhost:27017 / test”,后跟命令提示符。在mongo shell中的几个命令一切似乎都在那里工作。使两个端子都打开并运行。

我也确认我可以通过localhost到达web界面:28017。

我安装了node.js并添加了mongoose包。现在尝试使用超级简单的node.js应用程序进行连接(也可以本地登录用户身份运行):

var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/test');

我收到以下错误

events.js:72
        throw er; // Unhandled 'error' event
              ^
Error: connect ECONNREFUSED
    at errnoException (net.js:901:11)
    at Object.afterConnect [as oncomplete] (net.js:892:19)

把我的头靠在墙上,试图让一件如此简单的工作。我失踪了什么

编辑:这里是mongod的日志。正如你所看到的,我尝试了多次,他们都是失败的,而不是瞬间的

Thu Dec  5 08:19:43.700 [initandlisten] MongoDB starting : pid=14412 port=27017 dbpath=/usr/local/var/mongodb 64-bit host=mobadmins-MacBook-Pro-3.local
           08:19:43.700 [initandlisten] db version v2.4.8
           08:19:43.700 [initandlisten] git version: nogitversion
           08:19:43.700 [initandlisten] build info: Darwin mobadmins-MacBook-Pro-3.local 12.4.0 Darwin Kernel Version 12.4.0: Wed May  1 17:57:12 PDT 2013; root:xnu-2050.24.15~1/RELEASE_X86_64 x86_64 BOOST_LIB_VERSION=1_49
           08:19:43.700 [initandlisten] allocator: tcmalloc
           08:19:43.700 [initandlisten] options: { bind_ip: "127.0.0.1",config: "/usr/local/etc/mongod.conf",dbpath: "/usr/local/var/mongodb",logappend: "true",logpath: "/usr/local/var/log/mongodb/mongo.log",rest: true }
           08:19:43.700 [initandlisten] journal dir=/usr/local/var/mongodb/journal
           08:19:43.700 [initandlisten] recover : no journal files present,no recovery needed
           08:19:43.729 [websvr] admin web console waiting for connections on port 28017
           08:19:43.729 [initandlisten] waiting for connections on port 27017
           08:22:34.561 [initandlisten] connection accepted from 127.0.0.1:52160 #3 (1 connection Now open)
           08:22:34.563 [conn3] recv(): message len 1124073472 is too large. Max is 48000000
           08:22:34.563 [conn3] end connection 127.0.0.1:52160 (0 connections Now open)
           08:24:41.298 [initandlisten] connection accepted from 127.0.0.1:52166 #4 (1 connection Now open)
           08:24:41.304 [conn4] end connection 127.0.0.1:52166 (0 connections Now open)
           08:25:06.938 [initandlisten] connection accepted from 127.0.0.1:52168 #5 (1 connection Now open)
           08:25:06.943 [conn5] end connection 127.0.0.1:52168 (0 connections Now open)
           08:25:18.220 [initandlisten] connection accepted from 127.0.0.1:52172 #6 (1 connection Now open)
           08:25:18.225 [conn6] end connection 127.0.0.1:52172 (0 connections Now open)
           08:25:38.811 [initandlisten] connection accepted from 127.0.0.1:52175 #7 (1 connection Now open)
           08:25:38.816 [conn7] end connection 127.0.0.1:52175 (0 connections Now open)

解决方法

使用此代码设置您的mongodb连接:

var mongoose = require('mongoose');

var mongoURI = "mongodb://localhost:27017/test";
var MongoDB = mongoose.connect(mongoURI).connection;
MongoDB.on('error',function(err) { console.log(err.message); });
MongoDB.once('open',function() {
  console.log("mongodb connection open");
});

在启动服务器时确保mongod正在运行。您是使用Express还是只使用一个简单的node.js服务器?使用上述代码,您收到的错误消息是什么?

相关文章

这篇文章主要介绍“基于nodejs的ssh2怎么实现自动化部署”的...
本文小编为大家详细介绍“nodejs怎么实现目录不存在自动创建...
这篇“如何把nodejs数据传到前端”文章的知识点大部分人都不...
本文小编为大家详细介绍“nodejs如何实现定时删除文件”,内...
这篇文章主要讲解了“nodejs安装模块卡住不动怎么解决”,文...
今天小编给大家分享一下如何检测nodejs有没有安装成功的相关...