繁体   English   中英

节点类型脚本ssh2连接在服务器上通过[preauth]断开连接

[英]node typescript ssh2 connection disconnected on server with [preauth]

使用ssh2模块,使用privateKey连接到服务器,我在身份验证日志中遇到错误。 日志如下所示。

设置连接的代码:

const Client = require('ssh2').Client;
const fs = require('fs');
const util = require('util');

const key = fs.readFileSync('/path/to/rsa_key');

const conn = new Client();
await conn.connect({
    host: '<REMOTE_IP>',
    port: 22,
    username: '<NAME>',
    privateKey: key,
    // @ts-ignore
    debug: (d) => {
        console.log(util.inspect(d));
    },
});

await this.performTask(conn, 'uptime');

async performTask(conn, command) {
    return new Promise((resolve, reject) => {
        // @ts-ignore
        conn.exec(command, (err, stream) => {
            if (typeof err !== 'undefined') {
                // On error, stream is undefined.
                console.error(`ERROR: ${err}`);
                reject(new Error(err));
            } else {
                // @ts-ignore
                stream.on('close', (code, signal) => {
                    console.log(`Stream :: close :: code: ${code} , signal: ${signal}`);
                    conn.end();
                    resolve();

                    // @ts-ignore
                }).on('data', (data) => {
                    console.log(`STDOUT: ${data}`);
                    // @ts-ignore
                }).on('error', (errrrrr) => {
                    console.error(`B ${errrrrr}`);
                    // @ts-ignore
                }).stderr.on('data', (data) => {
                    console.error(`STDERR: ${data}`);
                });
            }
        });
    });
}
Sep  2 22:04:27 <remote_host> sshd[9037]: Disconnected from <local_ip> port 38194 [preauth]

打开debug打印不同的内容。 这些2之一:

'DEBUG: Local ident: \'SSH-2.0-ssh2js0.4.4\''
'DEBUG: Client: Trying <REMOTE_IP> on port 22 ...'
'DEBUG: Outgoing: Writing CHANNEL_OPEN (0, session)'
'DEBUG: Client: Connected'
'DEBUG: Parser: IN_INIT'
'DEBUG: Parser: IN_GREETING'
'DEBUG: Parser: IN_HEADER'
'DEBUG: Remote ident: \'SSH-2.0-OpenSSH_7.6p1 Ubuntu-4ubuntu0.3\''
'DEBUG: Outgoing: Writing KEXINIT'
'DEBUG: Parser: IN_PACKETBEFORE (expecting 8)'
'DEBUG: Parser: IN_PACKET'
'DEBUG: Parser: pktLen:1076,padLen:6,remainLen:1072'
'DEBUG: Parser: IN_PACKETDATA'
'DEBUG: Parser: IN_PACKETDATAAFTER, packet: KEXINIT'
'DEBUG: Comparing KEXINITs ...'
<alogirthm comparisons, no error message, just print of what is picked>
'DEBUG: Outgoing: Writing KEXECDH_INIT'
'DEBUG: Parser: IN_PACKETBEFORE (expecting 8)'
events.js:174
      throw er; // Unhandled 'error' event
      ^

Error: write EPIPE
    at WriteWrap.afterWrite [as oncomplete] (net.js:788:14)
Emitted 'error' event at:
    at Socket.<anonymous> (....../node_modules/ssh2/lib/client.js:307:10)
    at Socket.emit (events.js:203:15)
    at errorOrDestroy (internal/streams/destroy.js:107:12)
    at onwriteError (_stream_writable.js:436:5)
    at onwrite (_stream_writable.js:461:5)
    at _destroy (internal/streams/destroy.js:49:7)
    at Socket._destroy (net.js:613:3)
    at Socket.destroy (internal/streams/destroy.js:37:8)
    at WriteWrap.afterWrite [as oncomplete] (net.js:790:10)

要么:

'DEBUG: Local ident: \'SSH-2.0-ssh2js0.4.4\''
'DEBUG: Client: Trying<REMOTE_IP> on port 22 ...'
'DEBUG: Outgoing: Writing CHANNEL_OPEN (0, session)'
'DEBUG: Client: Connected'
'DEBUG: Parser: IN_INIT'
'DEBUG: Parser: IN_GREETING'
'DEBUG: Parser: IN_HEADER'
'DEBUG: Remote ident: \'SSH-2.0-OpenSSH_7.6p1 Ubuntu-4ubuntu0.3\''
'DEBUG: Outgoing: Writing KEXINIT'
ERROR: Error: No response from server

这些情况中的任何一种都不会发生可预测的模式。

现在,您必须等待'ready'事件,然后再发出命令,因为在完全准备好连接之前,当前没有使用请求/命令队列。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM