0

我在我的 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
4

3 回答 3

1

确保端口27017对 Ubuntu 中的 Web 服务器开放。

于 2012-09-26T20:46:47.177 回答
1

我发现问题了!!系统有一个混乱的 /etc/hosts 文件。与 localhost 配置不同的东西。更正这个文件解决了一切:D

于 2012-09-27T09:32:14.710 回答
0

尝试mongo从终端触发命令。如果 mongodb 出现问题,它将显示错误。

于 2012-09-27T05:56:05.180 回答