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
本地主机给了我一个权限被拒绝的错误,后者给了我一个超时
正如 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)
| 归档时间: |
|
| 查看次数: |
14883 次 |
| 最近记录: |