我已经使用如下命令通过 CLI 成功 ssh
进入 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
,因为我正在调试 Node 脚本,当我 ssh
进入并关闭 session 时,我可以看到日志条目CLI,但是当我尝试通过 Node ssh2
时什么也没有。
什么可能导致此连接无提示地失败?
最佳答案
更新:据我所知,您的客户端将记录服务器标识字符串,并在连接后立即发送。因此,如果您没有看到该信息,则一定是服务器没有发送任何内容。 现在,由于您尝试使用 CLI SSH 并且它有效,一旦我们排除了不可能的情况,唯一剩下的解释(看起来不太可能)是您没有连接到同一服务器/端口。由于某种原因,目标服务器上的端口 8080 未运行 SSH2 服务器。
一个 可能的解释是:服务器正在端口 8080 上运行其他东西,允许连接但最初不发送任何东西(例如 HTTP 服务器)。当您使用 CLI SSH 连接时,您认为它正在使用端口 8080,但出于某种原因,ssh_config 文件中的指令没有启动,并且 CLI SSH 连接到真正的 SSH 服务器,并工作,而 Node SSH 连接到不同的服务器,这就是它不工作的原因。
要检查,请尝试远程登录到该服务器的端口 8080 并验证它是否以 SSH2 标语响应:
Connected to xxx.xxx.xxx.xxx port 22
Escape character is '^]'.
SSH-2.0-OpenSSH_6.6.1p1 Ubuntu-2ubuntu2.8
^C
Connection closed by foreign host.
如果它没有用“SSH-...”横幅回答,我认为这足以证明 CLI SSH 正在连接其他地方。在哪里?要发现这一点,请使用调试再次运行 CLI SSH:
ssh -vvv xxx.xxx.xxx.xxx ... 2>&1 | grep "Connecting to"
(您必须按 Ctrl-C 退出)。这应该给你:
debug1: Connecting to whatever [xxx.xxx.xxx.xxx] port XYZK
而 xxx.xxx.xxx.xxx 和 XYZK 值是您需要传递给 node
客户端的值。
上一个答案
我不熟悉 nodejs
的 SSH2,但几个月前我有一个 SSH2 库(当时是封闭源)对我玩这个把戏。 “已连接...”后跟 nothing。
事实证明,客户端使用的是服务器不支持的密码,出于某种原因,虽然 OpenSSH2 的 CLI 客户端显示了这一点,但库选择不显示错误。追根究底非常麻烦。
我从 GitHub 页面上看到一些密码需要“Node v0.11.12 或更新版本”。这是你的情况吗?如果没有,您可能想尝试更新 node
。
在任何情况下,我都会遵循@AttRigh 的建议并在服务器上以 Debug模式运行 sshd。如果你不能:
- 在完全 Debug模式下记录 ssh2 CLI 客户端的输出并提取它使用的密码,
- 使用该密码设置 sshd 服务器,不使用其他密码,
- 针对该服务器运行您的 Node 客户端。
此外,既然我想到了,您无论如何都可以使用默认设置设置一个 sshd 服务器,并确保您可以连接到那个。这会在某种程度上限制问题。
关于javascript - ssh2 模块静默失败,凭据从 CLI 成功,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41885978/