javascript - ssh2 模块静默失败,凭据从 CLI 成功

标签 javascript node.js linux ssh google-cloud-platform

我已经使用如下命令通过 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/

相关文章:

javascript - 如何匹配一个贪婪量化的非 -'[' 字符字符串,其中任何地方都不包含字符串 '->'?

javascript - 如何在html中显示多个json结果

javascript - 没有找到类验证器的元数据

linux - Linux(64 位)org.openqa.selenium.NoSuchElementException 上的 phantomjs 异常错误

c - 使用O_CREAT时open的执行

javascript - 遇到 webpack 模块解析问题

javascript - 滚动到 iframe 中的特定 ID,同时保留父页面位置

javascript - 用于用户事件的 Node + Github webhook

javascript - meteor js创建mongodb数据库钩子(Hook)以固定间隔存储来自API的数据

Linux 上的 Java 2D 页面翻转