如何使用 Node.js 建立到 MongoDB 数据库的 SSH 隧道连接

use*_*714 2 ssh mongoose mongodb node.js ssh-tunnel

我的凭据与 Robomongo 完美配合,但我无法与 node.js 建立连接
我曾尝试使用 ssh2 和 tunnel-ssh npm 模块建立连接,但两次都失败了。
- mongo 连接不需要密码
- ssh 连接是使用 pem 密钥建立的

这是我在 ssh2 模块中使用的代码,我可以正确建立隧道,但 mongo 连接失败

var Client = require('ssh2').Client;

var conn = new Client();
conn.on('ready', function() {
    console.log('Client :: ready');
    //mongo connection
        mongoose.connect('mongodb://localhost:27000/');
        var db = mongoose.connection;
        db.on('error', console.error.bind(console, 'connection error:'));
        db.once('open', function() {
            console.log("database connection established");
            var users = db.collection('user');
            var getallUsers = function (date, callback){
                users.find({}).toArray(function(err,data){
                    callback(data);
                })
            };
            getallUsers(null, function (data){
                console.log('data :'+  data);
            });
        });
    //end of mongo connection
}).connect({
    host: '**.**.**.**.**',
    port: 22,
    username: 'ec2-user',
    privateKey: key
});
Run Code Online (Sandbox Code Playgroud)

以及隧道 ssh 的代码

var config = {
    dstPort: 27000,
    user: 'ec2-user',
    host: '**.**.**.**.**',
    privateKey: key
};

var server = tunnel(config, function (error, server) {
    if(error){
        console.log("SSH connection error: " + error);
    }
    console.log('database connection initalizing');
    mongoose.connect('mongodb://localhost:27000/');

    var db = mongoose.connection;

    db.on('error', console.error.bind(console, 'connection error:'));
    db.once('open', function() {

        console.log("database connection established");

        var users = db.collection('user');
        var getallUsers = function (date, callback){
            users.find({}).toArray(function(err,data){
                callback(data);
            })
        };
        getallUsers(null, function (data){
            console.log(data);
        });

    });
});
Run Code Online (Sandbox Code Playgroud)

我不确定是在建立隧道后使用常规的 MongoDB 连接字符串还是将数据库称为 localhost,例如
mongodb://localhost:portnumber。

mongodb://databasepath.subpath.mongodbdns.com:27000

本地主机给了我一个权限被拒绝的错误,后者给了我一个超时

use*_*714 6

正如 mscdex 所提到的,ssh2 不是用于建立到数据库的 ssh 隧道连接的好模块。隧道 ssh 更合适。

以下是我使用的配置选项:

dstPort:远程数据库连接端口

localPort:与 dstPort 相同,它将是您将用于本地机器的端口

用户名:SSH 用户名,

主机:SSH地址

dstHost: 数据库连接 url (...mongodbns.com) ,

私钥:SSH 密钥

然后一旦您的隧道连接,通过猫鼬连接到您的本地主机,例如 mondodb://localhost:27000(使用您在 localPort 中定义的 localport)

var server = tunnel(config, function (error, server) {
    if(error){
        console.log("SSH connection error: " + error);
    }
    mongoose.connect('mongodb://localhost:27000/');
    //...rest of mongoose connection
}
Run Code Online (Sandbox Code Playgroud)

  • 我得到这个>> **错误:所有配置的身份验证方法都失败** 注意:我正在使用 **require('mongodb').MongoClient ,require('tunnel-ssh'),var config = { username: 'root ', 密码: 'xxxxxx', 主机: "xx11.130", dstHost: "xx11.130", 端口: 22, dstHost:url, dstPort: 10945, localPort: 10945 };** (2认同)