【发布时间】:2017-06-12 15:54:56
【问题描述】:
我已通过 CLI 使用如下命令成功 ssh'd 进入 Google Cloud Compute:
ssh -i ~/.ssh/my-ssh-key me@ipnumber
但是使用ssh2 模块并没有给出任何输出,包括错误。
var fs = require('fs');
var Client = require('ssh2').Client;
var connSettings = {
host: IP, // 'XXX.XXX.XXX.XX'
port: PORT, // XXXX
username: ME,
privateKey: privateKey, //fs.readFileSync(location, 'utf8')
passphrase: passphrase,
password: password
};
var conn = new Client();
conn.on('ready', function() { //first example in README
console.log('Client :: ready');
conn.exec('uptime', function(err, stream) {
if (err) throw err; //nothing
stream.on('close', function(code, signal) {
console.log('Stream :: close :: code: ' + code + ', signal: ' + signal); //nothing
conn.end();
}).on('data', function(data) {
console.log('STDOUT: ' + data); //nothing
}).stderr.on('data', function(data) {
console.log('STDERR: ' + data); //nothing
});
});
})
.on('error', function(err) {
console.error('err', error); //nothing
})
.connect(connSettings);
我正在跟踪/var/log/secure,因为我正在调试节点脚本,当我进入ssh 并从CLI 关闭会话时,我可以看到日志条目,但是当我尝试通过节点ssh2 时什么也没有。
什么可能导致此连接静默失败?
【问题讨论】:
-
错误的端口,它正在等待握手超时?尝试将
debug: console.log添加到您的连接配置中,以查看幕后发生/未发生的事情。 -
@mscdex 当我记录该对象时,我可以看到它们都是正确的。似乎至少应该有一些错误。
-
当您将
debug: console.log添加到您的connSettings对象时,它应该将调试输出打印到您的终端/控制台。将其复制到要点或其他内容并在此处链接到它。 -
如果不能查看请求的(完整)调试输出,这很难说。另外,您确定端口 8080 是正确的端口吗?您没有显示在您的 OpenSSH 客户端示例中使用的端口。
-
如果 strace 方法不起作用并且您可以访问服务器,您可以在机器上运行第二个 ssh 服务器并进行大量调试:
/usr/sbin/sshd -D -p $NEW_PORT -d -d -d(此输出包含敏感信息)
标签: javascript node.js linux ssh google-cloud-platform