前端自动化部署之ssh2和ssh2-sftp-client

ssh2-sftp-client 本身是一个专门用于处理 SFTP文件操作的库,它不直接提供执行远程命令的功能。但是可以通过它的底层依赖库 ssh2 实现执行命令的功能。

以下是实现方法和示例代码:


方法一:使用 ssh2 执行远程命令

ssh2ssh2-sftp-client 的底层库,它支持执行远程命令。

安装依赖

如果尚未安装 ssh2,可以通过以下命令安装:

bash 复制代码
npm install ssh2
代码示例
javascript 复制代码
const { Client } = require('ssh2');

const serverOptions = {
  host: 'your-server-ip',
  port: 22,
  username: 'your-username',
  password: 'your-password', // 或者使用 privateKey
};

const command = 'ls -l /home/cuijiying/log_tools';

const conn = new Client();

conn.on('ready', () => {
  console.log('SSH 连接成功!');
  conn.exec(command, (err, stream) => {
    if (err) throw err;

    stream
      .on('close', (code, signal) => {
        console.log(`命令执行完成,退出代码:${code}`);
        conn.end();
      })
      .on('data', (data) => {
        console.log('输出:\n' + data.toString());
      })
      .stderr.on('data', (data) => {
        console.error('错误:\n' + data.toString());
      });
  });
}).connect(serverOptions);
输出解释
  • 标准输出通过 stream.on('data') 接收。
  • 错误输出通过 stream.stderr.on('data') 接收。

方法二:结合 ssh2-sftp-clientssh2

如果你同时需要执行命令和进行 SFTP 文件操作,可以同时使用 ssh2ssh2-sftp-client

代码示例
javascript 复制代码
const { Client } = require('ssh2');
const SftpClient = require('ssh2-sftp-client');

const serverOptions = {
  host: 'your-server-ip',
  port: 22,
  username: 'your-username',
  password: 'your-password',
};

const command = 'df -h'; // 示例命令:查看磁盘使用情况
const sftp = new SftpClient();
const conn = new Client();

async function executeCommand() {
  return new Promise((resolve, reject) => {
    conn.on('ready', () => {
      console.log('SSH 连接成功!');
      conn.exec(command, (err, stream) => {
        if (err) return reject(err);

        let output = '';
        stream
          .on('close', (code, signal) => {
            console.log(`命令执行完成,退出代码:${code}`);
            conn.end();
            resolve(output);
          })
          .on('data', (data) => {
            output += data.toString();
          })
          .stderr.on('data', (data) => {
            console.error('错误:\n' + data.toString());
          });
      });
    }).connect(serverOptions);
  });
}

async function main() {
  try {
    // 执行远程命令
    const commandOutput = await executeCommand();
    console.log('命令输出:\n', commandOutput);

    // 使用 SFTP 上传文件
    await sftp.connect(serverOptions);
    await sftp.put('./example.zip', '/home/cuijiying/example.zip');
    console.log('文件上传成功!');
  } catch (err) {
    console.error('操作失败:', err);
  } finally {
    sftp.end();
  }
}

main();

方法三:使用 ssh2 的高级特性(Shell 模式)

如果需要执行多个命令,可以使用 Shell 模式。

代码示例
javascript 复制代码
const { Client } = require('ssh2');

const serverOptions = {
  host: 'your-server-ip',
  port: 22,
  username: 'your-username',
  password: 'your-password',
};

const conn = new Client();

conn.on('ready', () => {
  console.log('SSH 连接成功!');
  conn.shell((err, stream) => {
    if (err) throw err;

    stream
      .on('close', () => {
        console.log('Shell 会话结束');
        conn.end();
      })
      .on('data', (data) => {
        console.log('输出:\n' + data.toString());
      });

    // 执行多个命令
    stream.write('pwd\n');
    stream.write('ls -l\n');
    stream.write('exit\n');
  });
}).connect(serverOptions);

注意事项

  1. 权限问题

    • 确保 SSH 用户具有执行命令的权限。如果是限制用户(如 chroot 环境),可能无法正常执行某些命令。
  2. 命令路径

    • 某些命令可能需要完整路径,例如 /usr/bin/ls 而非 ls
  3. 错误处理

    • 捕获所有异常,并合理处理连接超时或命令失败等问题。
  4. 谨慎使用rm 相关命令

    • 哈哈,这是一个极其危险的命令,不懂得可以自行搜索。

通过以上方法,你可以在 Node.js 环境中使用 ssh2 执行远程命令,同时结合 ssh2-sftp-client 进行文件传输,满足大多数 SSH 操作需求。

相关推荐
ZCXZ12385296a13 分钟前
物流自动化环境下的纸箱检测与识别_YOLO13-SEG-REPVGGOREPA模型应用
运维·自动化
咔咔一顿操作21 分钟前
轻量无依赖!autoviwe 页面自适应组件实战:从安装到源码深度解析
javascript·arcgis·npm·css3·html5
刘联其33 分钟前
.net也可以用Electron开发跨平台的桌面程序了
前端·javascript·electron
韩曙亮33 分钟前
【jQuery】jQuery 选择器 ④ ( jQuery 筛选方法 | 方法分类场景 - 向下找后代、向上找祖先、同级找兄弟、范围限定查找 )
前端·javascript·jquery·jquery筛选方法
前端 贾公子33 分钟前
Node.js 如何处理 ES6 模块
前端·node.js·es6
qinyia37 分钟前
**使用AI助手在智慧运维中快速定位并修复服务异常:以Nginx配置错误导致502错误为例**
linux·运维·服务器·数据库·mysql·nginx·自动化
ONLYOFFICE39 分钟前
ONLYOFFICE 自动化工具:宏和 AI 函数如何选择?
运维·自动化·编辑器·onlyoffice
pas13639 分钟前
42-mini-vue 实现 transform 功能
前端·javascript·vue.js
你的代码我的心1 小时前
微信开发者工具开发网页,不支持tailwindcss v4怎么办?
开发语言·javascript·ecmascript
esmap1 小时前
OpenClaw与ESMAP AOA定位系统融合技术分析
前端·人工智能·计算机视觉·3d·ai·js