轻量运维工具fastdp

最近我开发了一款轻量运维工具 fastdp,基于 Go 语言实现,核心优势只有一个:快! 在相同环境下,批量命令执行速度比 Ansible 快 18 倍,且用法更简单。今天就来分享这个工具的设计思路和使用方法。

而 fastdp 的设计目标是:抛弃冗余功能,专注 "批量执行命令 / 文件操作" 的核心场景,用 Go 的协程优势实现极致性能。

性能对比:18 倍提速是怎么来的?

直接上测试数据:在 4 台同网段 Linux 主机(网络延迟 <1ms)上执行 date 命令,对比结果如下:

工具 实际耗时(real) 差异点
fastdp 0m0.135s 基于 Go 协程并发,无进程开销
Ansible 0m2.523s Python 多进程模型,启动成本高

为什么 fastdp 这么快?

协程级并发:

用 Go 原生 Goroutine 管理 SSH 连接,避免 Ansible 的 "多进程 fork 开销",100 台主机并发连接只需 1 个进程,内存占用不到 10MB。

无冗余设计:

摒弃 Ansible 的 "兼容全场景" 逻辑(比如复杂的模块参数校验、多版本 Python 适配),无需复杂依赖,专注 "批量执行命令 / 文件操作",代码量仅 2000 行。

轻量配置:

命令行直接传参,主机组配置用简单的 [组名] 格式,与ansible风格类似,上手成本极低。二进制文件大小只有10MB左右

fastdp 快速开始(Linux amd64)

  1. 下载发行包

使用 wgetcurl 下载 amd64 架构的发行包:

bash 复制代码
bash
# 使用 wget
# amd64版本
wget https://gitee.com/zhao-pengfei2/fastdp/releases/download/fastdp-v1/fastdp-v1-linux-amd64.tar.gz
 
# arm64版本
wget https://gitee.com/zhao-pengfei2/fastdp/releases/download/fastdp-v1/fastdp-v1-linux-arm64.tar.gz
  1. 解压文件

解压下载的压缩包,获取二进制文件和配置模板:

bash 复制代码
bash
# 解压到当前目录,以amd64版本为例
tar -zxvf fastdp-v1-linux-amd64.tar.gz
# 解压后会生成 fastdp 目录,包含二进制文件和配置示例
cd fastdp
  1. 安装方式
bash 复制代码
bash
# 复制二进制文件到 /usr/local/bin(无需额外配置 PATH)
cp fastdp /usr/local/bin/
 
# 复制配置文件模板到系统配置目录
mkdir -p /etc/fastdp
cp config.toml host /etc/fastdp/
 
# 编辑/etc/fastdp/host文件,添加主机信息
vim /etc/fastdp/host

fastdp 能做什么?3 个核心场景

  1. 批量执行命令:一行命令搞定

最常用的场景:给 web 组主机执行 uptime 命令

bash 复制代码
bash
# 格式:fastdp [命令参数] 主机组/IP
fastdp shell -a "uptime" web
  1. 跨机文件复制

复制本地 config.ini 到 db 组主机的 /etc/app/ 目录,只需指定源路径和目标路径:

arduino 复制代码
bash
fastdp copy -s ./config.ini -d /etc/app/config.ini db

fastdp 会自动做两件事:

  • 对比本地与远程文件的 MD5,避免重复传输;
  • 同步源文件的权限(如 rw-r--r--)到远程,无需额外配置。
  1. 主机连通性检测:批量 SSH 存活检查

快速检测 all 组主机的 SSH 端口是否可达(比 ping 更实用):

css 复制代码
bash
fastdp ping all

目前 fastdp 已支持 shell/copy/ping 三个核心模块。

仓库地址:gitee.com/zhao-pengfe...

最后求个 Star 🌟,你的支持是我继续优化的动力!

相关推荐
神奇的程序员7 天前
实现一个内网服务监测告警系统
后端·自动化运维
智能运维指南12 天前
2025自动化巡检能力:自动化运维厂商如何破解合规与效率双重难题?
自动化运维·自动化巡检·自动化运维系统·it巡检·运维自动化·国产自动化运维厂商·国产自动化运维平台
码途进化论13 天前
基于 Node.js 和 SSH2 的 Docker 自动化部署实践
前端·自动化运维
该用户已不存在13 天前
Let’s Encrypt 证书有效期将缩至 45 天,运维天都塌了
运维·https·自动化运维
kaliarch14 天前
2025年IaC生态全景与实践指南:从工具选型到多云治理
后端·云计算·自动化运维
刚哥的进化路19 天前
Linux系统日志管理完全教程:从基础查看 to 集中分析(附实战命令)
运维·自动化运维
互联网小顽童19 天前
Linux系统进阶管理教程:从基础操作到企业级运维(附实战命令)
运维·自动化运维
猿先生13320 天前
Docker Compose 部署certbot实现TLS证书签发和续期
自动化运维
Mintopia23 天前
🌐 多用户并发请求下的 WebAIGC 服务稳定性技术保障
javascript·人工智能·自动化运维
温蒂来啦25 天前
Playwright最常用的功能语句汇总
自动化运维