无法从Ubuntu上的NodeJS连接到MongoDB。 OSX上的相同代码工作正常

时间:2012-09-26 20:22:25

标签: node.js mongodb ubuntu express mongoose

我在我的osx笔记本电脑和远程ubuntu服务器上本地安装了mongodb。两者都运行了mongodb,我可以使用端口28017上的http诊断来验证这一点。我在两台计算机上运行相同的代码。在osx上一切正常,但在Ubuntu上我无法通过NodeJS建立与数据库的连接。我一直收到这个错误:

Error: failed to connect to [localhost:27017]]
message:  listen EADDRNOTAVAIL
stack:  Error: listen EADDRNOTAVAIL
    at errnoException (net.js:769:11)
    at Server._listen2 (net.js:892:19)
    at listen (net.js:936:10)
    at Server.listen (net.js:993:9)
    at asyncCallback (dns.js:67:16)
    at Object.onanswer [as oncomplete] (dns.js:120:9)

我不明白的是我可以通过mongo命令行界面在本地连接Ubuntu。我也可以通过我的OSX计算机上的mongo命令连接到Ubuntu上的数据库。所以MongoDB本身的安装似乎没什么问题。

有人能想到我无法通过NodeJS连接的原因吗?我尝试过使用mongodb和mongoose包。两者都给我同样的错误。

以下是我尝试的两种方法:

var mongo = require("mongodb");
var host = "localhost";
var port = mongo.Connection.DEFAULT_PORT;
var db = new mongo.Db('node-mongo-examples', new mongo.Server(host, port, {}), {});
db.open(function(err, db){
    if(err){
        log.error('MongoDB connection error:', err);
    }else{
        log.info("OPEN MONGO CONNECTION");
    }
});

和猫鼬一起:

var mongoose = require('mongoose');
var db = mongoose.createConnection('localhost', 'node-mongo-examples');

db.on('error', function(err){
  log.error('MongoDB connection error:', err);
});

db.once('open', function () {
  log.debug("OPEN MONGO CONNECTION");
});

在日志中,我看到没什么特别的,也没有任何事情发生

***** SERVER RESTARTED *****

Wed Sep 26 18:00:18 [initandlisten] MongoDB starting : pid=13377 port=27017 dbpath=/var/lib/mongodb 64-bit host=octo-dev
Wed Sep 26 18:00:18 [initandlisten] db version v2.2.0, pdfile version 4.5
Wed Sep 26 18:00:18 [initandlisten] git version: f5e83eae9cfbec7fb7a071321928f00d1b0c5207
Wed Sep 26 18:00:18 [initandlisten] build info: Linux ip-10-2-29-40 2.6.21.7-2.ec2.v1.2.fc8xen #1 SMP Fri Nov 20 17:48:28 EST 2009 x86_64 BOOST_LIB_VERSION=1_49
Wed Sep 26 18:00:18 [initandlisten] options: { config: "/etc/mongodb.conf", dbpath: "/var/lib/mongodb", logappend: "true", logpath: "/var/log/mongodb/mongodb.log" }
Wed Sep 26 18:00:18 [initandlisten] journal dir=/var/lib/mongodb/journal
Wed Sep 26 18:00:18 [initandlisten] recover : no journal files present, no recovery needed
Wed Sep 26 18:00:18 [websvr] admin web console waiting for connections on port 28017
Wed Sep 26 18:00:18 [initandlisten] waiting for connections on port 27017

.....除非我通过mongo命令行界面连接:

Wed Sep 26 18:30:40 [initandlisten] connection accepted from 127.0.0.1:38229 #3 (1 connection now open)

我没有尝试过的东西了。对此进行故障排除的任何建议?


一些额外的信息

sudo netstat -tulpn
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name
tcp        0      0 0.0.0.0:27017           0.0.0.0:*               LISTEN      13377/mongod    
tcp        0      0 127.0.0.1:3306          0.0.0.0:*               LISTEN      885/mysqld      
tcp        0      0 0.0.0.0:1935            0.0.0.0:*               LISTEN      1102/java       
tcp        0      0 0.0.0.0:9999            0.0.0.0:*               LISTEN      1102/java       
tcp        0      0 192.87.219.76:10000     0.0.0.0:*               LISTEN      31171/webserver 
tcp        0      0 0.0.0.0:8080            0.0.0.0:*               LISTEN      1387/java       
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      1076/apache2    
tcp        0      0 0.0.0.0:28017           0.0.0.0:*               LISTEN      13377/mongod    
tcp        0      0 0.0.0.0:48466           0.0.0.0:*               LISTEN      12418/java      
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      3507/sshd       
tcp        0      0 127.0.0.1:9016          0.0.0.0:*               LISTEN      12418/java      
tcp        0      0 0.0.0.0:5080            0.0.0.0:*               LISTEN      1102/java       
tcp        0      0 0.0.0.0:25              0.0.0.0:*               LISTEN      1216/master     
tcp        0      0 0.0.0.0:41018           0.0.0.0:*               LISTEN      12418/java      
tcp        0      0 0.0.0.0:8443            0.0.0.0:*               LISTEN      1102/java       
tcp        0      0 0.0.0.0:9090            0.0.0.0:*               LISTEN      12418/java      
tcp        0      0 0.0.0.0:29090           0.0.0.0:*               LISTEN      12418/java      
tcp        0      0 127.0.0.1:8100          0.0.0.0:*               LISTEN      8535/soffice.bin
tcp        0      0 127.0.0.1:8005          0.0.0.0:*               LISTEN      1387/java       
tcp        0      0 0.0.0.0:389             0.0.0.0:*               LISTEN      887/slapd       
tcp        0      0 0.0.0.0:33736           0.0.0.0:*               LISTEN      1102/java       
tcp6       0      0 :::22                   :::*                    LISTEN      3507/sshd       
tcp6       0      0 :::389                  :::*                    LISTEN      887/slapd       
udp        0      0 192.87.219.76:123       0.0.0.0:*                           721/ntpd        
udp        0      0 127.0.0.1:123           0.0.0.0:*                           721/ntpd        
udp        0      0 0.0.0.0:123             0.0.0.0:*                           721/ntpd        
udp        0      0 0.0.0.0:5353            0.0.0.0:*                           797/avahi-daemon: r
udp        0      0 0.0.0.0:55248           0.0.0.0:*                           797/avahi-daemon: r
udp6       0      0 :::123                  :::*                                721/ntpd        
udp6       0      0 :::35920                :::*                                797/avahi-daemon: r
udp6       0      0 :::5353                 :::*                                797/avahi-daemon: r

3 个答案:

答案 0 :(得分:1)

确保在Ubuntu中为Web服务器打开端口27017

答案 1 :(得分:1)

我发现了问题!!系统有一个混乱的/ etc / hosts文件。使用localhost配置的东西是不寻常的。纠正这个文件解决了所有问题:D

答案 2 :(得分:0)

尝试从终端触发mongo命令。如果mongodb存在问题,则会显示错误。