有Trae助力1天时间用Node搞了个SSH命令行工具!解放双手~

哈喽哇!我是小不不简说的不。在代码世界疯狂蹦跶的 "非资深选手"🙋‍♂️!主打一个*"踩坑我来,避坑你学"*。毕竟独乐乐不如众乐乐,让大家少走弯路,才是咱的终极使命✨~

之前写了一篇工程化实战,用 Nodejs 自动部署前端项目。

又想偷懒,不CV代码。所以搞了个工具☺️

今天借助Trae,狠狠的升级了一波。让它更通用。并且开源啦~ github.com/CcSimple/sv...

先看效果

sv-ssh: 服务器操作自动化工具

一个基于Node.js的命令行工具,帮助开发者通过SSH自动化服务器操作流程,支持自定义配置和操作流程定义。

✨ 特性

  • 交互式配置服务器连接信息
  • 支持自定义环境变量文件和操作流程文件
  • 内置文件压缩、上传、移动、复制、重命名、解压、命令行、删除等操作
  • 支持自定义操作函数,扩展功能
  • 代码风格统一(ESLint + Prettier)
  • 支持多个配置文件,每个文件对应不同的服务器环境或操作流程

全局安装

bash 复制代码
npm install -g sv-ssh
# 初始化配置
sv-ssh init
# 运行操作流程
sv-ssh run

项目内安装

bash 复制代码
npm install sv-ssh --save-dev
# 添加到package.json脚本
# "scripts": {
#   "init": "sv-ssh init",
#   "run": "sv-ssh run"
# }

⚙️ 命令说明

1. 初始化配置文件

使用init命令创建配置文件和操作流程模板:

bash 复制代码
# 默认初始化
#(生成.sv-ssh.env和sv-ssh-actions.js)
sv-ssh init

# 自定义环境变量文件名和操作流程文件名
sv-ssh init -e my-env.env -a my-actions.js

init命令选项:

  • -e, --env <filename>: 自定义环境变量文件名(默认:.sv-ssh.env)
  • -a, --actions <filename>: 自定义操作流程文件名(默认:sv-ssh-actions.js)

执行后将引导您输入服务器IP、端口、用户名、密码和密钥文件路径等配置信息。密钥文件默认路径:

  • macOS/Linux: ~/.ssh/id_rsa
  • Windows: C:\Users\用户名.ssh\id_rsa

2. 执行操作流程

执行时将读取环境变量文件中的服务器配置,并按照操作流程文件中的定义执行一系列SSH操作。

使用run命令执行定义的操作流程:

bash 复制代码
# 使用默认配置文件执行
sv-ssh run

# 指定自定义配置文件
sv-ssh run -e my-env.env -o my-actions.js

run命令选项:

  • -e, --env <filename>: 指定环境变量文件(默认:.sv-ssh.env)
  • -a, --actions <filename>: 指定操作流程文件(默认:sv-ssh-actions.js)

多个配置文件支持! run 不指定配置文件时,提供选择列表,默认使用 .sv-ssh.env 和 sv-ssh-actions.js。
您可以新增 .sv-ssh-ignore 文件,支持选择列表过滤的文件。

bash 复制代码
# .sv-ssh-ignore
.pro.env
.test.env
.eslintrc.js
.prettierrc.js

默认排除以下文件

js 复制代码
[
  '.eslintrc.js',
  'rollup.config.js',
  '.prettierrc.js',
  'webpack.config.js',
  'vite.config.js',
  'gulpfile.js',
  'jest.config.js',
  'mocha.config.js',
  'vue.config.js',
  'next.config.js',
  'nuxt.config.js',
  'husky.config.js',
  'lint-staged.config.js',
  'deploy.js',
  'setup.js',
  'server.js',
  'babel.config.js',
  'commitlint.config.js',
];

📝 配置文件说明

环境变量文件 (.sv-ssh.env)

ini 复制代码
# 服务器连接配置
HOST=your.server.ip
PORT=22
USERNAME=your-username
PASSWORD=your-password
PRIVATE_KEY=/path/to/private/key

操作流程文件 (sv-ssh-actions.js)

javascript 复制代码
/**
 * 操作流程配置文件
 * 支持的操作类型:
 * - compress: 本地文件压缩
 * - upload: 文件上传到服务器
 * - move: 服务器文件移动
 * - copy: 服务器文件复制
 * - rename: 服务器文件重命名
 * - unzip: 服务器文件解压
 * - delete: 服务器文件删除
 * - command: 执行服务器命令
 * - custom: 自定义操作函数
 */
export default [
  {
    name: '压缩本地文件',
    type: 'compress',
    localDir: './dist',
    outputPath: './dist.zip',
    options: { zlib: { level: 9 } },
  },
  {
    name: '上传到服务器',
    type: 'upload',
    localPath: './dist.zip',
    remotePath: '/tmp/dist.zip',
    options: { createDir: true },
  },
  // 更多操作... 见仓库说明
];

自定义操作 (custom)

  • 执行自定义JavaScript函数
  • 参数 :
    • function: 自定义异步函数,接收参数 (ssh, config, action, actionsConfig, previousOutput)
      • ssh: SSH2连接实例
      • previousOutput: 前一步操作的输出结果
      • config: 配置对象,包含连接信息
      • action: 当前操作配置对象
      • actionsConfig: 所有操作配置数组
  • 示例:
javascript 复制代码
{
  name: '自定义部署检查',
  type: 'custom',
  function: async (ssh, previousOutput, config, action, actionsConfig) => {
    console.log('执行自定义健康检查...');
    const { stdout } = await ssh.execCommand('curl -s http://localhost/health');
    if (!stdout.includes('OK')) {
      throw new Error('服务健康检查失败');
    }
  }
}

开源地址

github.com/CcSimple/sv...

gitee.com/CcSimple/sv...

写到最后

💡 温馨提示:本文章可随意 "转发扩散",让更多小伙伴加入 "少踩坑联盟"!毕竟独坑坑不如众坑坑...... 啊不,是独乐乐不如众乐乐😂!

👉 快来关注小不悄悄说:评论区蹲一个 "你最想知道的代码小技巧,demo",下一期说不定就为你量身定制啦🎯!

相关推荐
濮水大叔23 分钟前
VonaJS: I18n如何支持Swagger多语言
typescript·node.js·nestjs
软件供应链安全指南44 分钟前
“基于‘多模态SCA+全周期协同’的中间件开源风险治理实践”荣获OSCAR开源+安全及风险治理案例
安全·中间件·开源
CoderJia程序员甲1 小时前
GitHub 热榜项目 - 日榜(2025-11-11)
ai·开源·大模型·github·ai教程
孟陬1 小时前
Bun Test 不支持时间快进?我用这招让单元测试提速 8 倍!
node.js·测试·bun
Less^_^2 小时前
使用 Node.js 开发 Telegram Bot 完整指南
ai·node.js
防火墙在线11 小时前
前后端通信加解密(Web Crypto API )
前端·vue.js·网络协议·node.js·express
水冗水孚16 小时前
效能工具(九)之编写nodejs脚本使用get-video-duration批量读取视频时长,并生成sql语句修复数据库表字段值
sql·node.js
huangql52017 小时前
Vite与Webpack完全指南:从零开始理解前端构建工具
前端·webpack·node.js
api_1800790546017 小时前
【技术教程】Python/Node.js 调用拼多多商品详情 API 示例详解
大数据·开发语言·python·数据挖掘·node.js
用户479492835691521 小时前
你知道node背后的libuv是什么吗
node.js