告别繁琐脚本!用Spug实现高效可视化运维

前言

在传统运维工作中,脚本曾是自动化任务的得力助手——从部署应用到监控服务,从日志分析到故障排查,一行行Shell或Python代码承载着系统稳定运行的重任。然而,随着业务规模扩大、团队协作加强,纯脚本运维逐渐暴露出诸多痛点:缺乏统一管理、执行过程不可视、权限控制薄弱、操作记录难追溯……更别提对非开发背景成员而言,脚本门槛高、易出错,成为效率提升的瓶颈。

幸运的是,开源社区为我们带来了更优雅的解决方案。Spug——一个轻量级、零依赖、开箱即用的可视化运维平台,正悄然改变这一局面。它将繁琐的命令行操作转化为直观的图形界面,把散落各处的脚本整合进统一的任务调度中心,同时提供完善的用户权限体系、操作审计日志和实时执行反馈,真正实现“所见即所控”。

本文将带你走进Spug的世界,从安装配置到实战应用,手把手教你如何告别重复、混乱的脚本时代,拥抱高效、安全、可视化的现代运维新范式。无论你是DevOps工程师、系统管理员,还是希望提升团队协作效率的技术负责人,相信Spug都能为你打开一扇通往更智能运维的大门。

85416aef6ec59685c7960f4e687721a9

1.什么是Spug?

Spug是一个开源、轻量级、无依赖的 可视化运维管理平台,专为中小团队或个人开发者设计,旨在简化日常的服务器运维、任务调度和自动化操作。它通过Web界面将原本需要在命令行中执行的脚本、命令、部署流程等操作图形化、集中化,显著降低运维门槛,提升效率与安全性。

核心特点:

零依赖部署

  • Spug采用Python编写,内置Web服务和数据库(SQLite),无需额外安装MySQL、Redis 等组件,一条命令即可启动,部署极其简单。

可视化操作

  • 所有主机管理、脚本执行、定时任务、应用发布等操作均可通过浏览器完成,支持实时查看命令执行输出,告别“盲打”脚本。

多用户 & 权限控制

  • 支持多账号协作,可按角色分配权限(如管理员、普通用户),并对主机、任务、应用等资源进行细粒度授权,保障操作安全。

批量执行 & 主机分组

  • 可对单台或多台服务器批量执行Shell/Python脚本,支持主机组管理,适用于集群运维场景。

任务计划(定时任务)

  • 内置类似crontab的定时任务功能,可通过界面配置周期性脚本执行,并记录历史日志。

应用发布(CI/CD轻量支持)

  • 提供简单的应用部署流程,支持从Git拉取代码、执行构建脚本、远程同步文件、重启服务等,满足基础持续交付需求。

操作审计 & 日志追踪

  • 所有用户操作均有完整日志记录,包括执行人、时间、命令内容、输出结果等,便于回溯与审计。

完全开源 & 社区活跃

  • 项目托管于GitHub(https://github.com/spug-dev/spug),采用MIT协议,免费商用,社区持续更新维护。

适用场景:

  • 中小型企业DevOps自动化
  • 运维人员日常批量操作
  • 开发团队自助部署测试环境
  • 替代手写Shell脚本 + crontab的传统方式
  • 需要可视化、可追溯、可协作的轻量级运维平台

简而言之,Spug = 可视化 + 自动化 + 安全协作,是现代高效运维的“轻骑兵”。如果你厌倦了在终端里反复敲打命令、管理散落各处的脚本,Spug或许正是你一直在寻找的解决方案。

2.前提条件

2.1ssh远程连接到极空间

  • 开启【SSH 服务】
  • 使用终端(Windows PowerShell / Mac Terminal)登录:
ssh root@IP

没有ssh的小伙伴可以参考这篇文章:

连接成功:极空间别再吃灰了!开启SSH,秒变全能服务器! – cpolar 极点云官网

image-20260522154032880

2.2验证docker是否开启

使用命令:

docker -v 
systemctl status -v

没有docker的小伙伴可以参考这篇文章:极空间开箱实录:从拆箱到远程访问保姆级教程,30分钟上手! – cpolar 极点云官网

image-20251017103712618

3.部署Spug

通过Docker部署Spug:

在开始部署之前,确保你的系统已经安装了Docker。可以通过以下命令检查 Docker 是否已安装:

docker --version

image-20260507155742946

首先创建一下安装的目录并进入到该目录:

mkdir -p /docker/spug
chmod -R 777 /spug

image-20260528162916571

创建并编辑 docker-compose.yml文件:

vi docker-compose.yml
version: "3.3"
services:
  db:
    image: mysql:8.0
    container_name: spug-db
    restart: always
    networks:
      - spug-net
    #command: --port 3306 --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
    command:
      - --default-authentication-plugin=mysql_native_password
      - --character-set-server=utf8mb4
      - --collation-server=utf8mb4_unicode_ci
    volumes:
      - ./mysql:/var/lib/mysql
    environment:
      - MYSQL_DATABASE=spug
      - MYSQL_USER=spug
      - MYSQL_PASSWORD=spug.cc
      - MYSQL_ROOT_PASSWORD=spug.cc
  spug:
    image: openspug/spug-service
    container_name: spug
    privileged: true
    restart: always
    networks:
      - spug-net
    volumes:
      - ./service:/data/spug
      - ./repos:/data/repos
    ports:
      # 如果8086端口被占用可替换为其他端口,例如: - "8000:80"
      - "8086:80"
    environment:
      - MYSQL_DATABASE=spug
      - MYSQL_USER=spug
      - MYSQL_PASSWORD=spug.cc
      - MYSQL_HOST=db
      - MYSQL_PORT=3306
    depends_on:
      - db
networks:
  spug-net:

启动容器:

docker-compose up -d

image-20260528162824708

部署完成后,在浏览器中输入 http://极空间IP:8086 就能看到Spug的界面:

image-20260528162811604

4.部署Spug

4.1 创建spug用户

以下操作会创建一个用户名为 admin 密码为 admin 的管理员账户,可自行替换管理员 账户/密码

docker exec spug init_spug admin admin

image-20260528170231423

成功显示:

image-20260528170251771

登录:

image-20260528170216867

登录成功,开始配置:

image-20260528170621663

4.2 使用spug

点击新建主机:

b5d2e59c3362c852c8572c71145fd2f0

输入账户的密码,点击确定:

回到“主机管理页面”,就可以看到我们新增的主机:

85416aef6ec59685c7960f4e687721a9

点击“Web终端”:

49434c66d6365472d8201b197baf550b

就可以连接到目标主机:

10e3d0ccd7206fe9ef04c297a88b9698

也可以批量执行shell脚本和Python,添加想执行目标主机:

ab0717c036cb10f5fd276b9626308736

编写一个脚本,创建ooo目录,执行:

853e80f93d8c978e249593a57838342c

执行成功:

cc2537604e90cb4b7bf35edaaf5c8747

去目标目录查看,已经创建成功:

2ea3299767853aaacfe3eaba6afb31b5

也可以给目标目录上传文件:

306937673ec50f09c60c53103b6d8219

来到/app目录下,我们看见文件已经上传成功:

55d84a259d0c736ee2e26bed9e1c8403

还有更多特别精彩的内容等着你去发掘~

c8dfb10c5e1746b15221788b27bf092d

5.安装cpolar实现随时随地开发

5.1 什么是cpolar?

cpolar是一款安全高效的内网穿透工具,无需公网IP或复杂配置,只需一条命令,即可将本地服务器、Web服务或任意端口映射到公网,让你随时随地远程访问内网应用,特别适合开发调试、远程运维和应急部署等场景。

5.2 部署cpolar

cpolar 可以将你本地电脑中的服务(如 SSH、Web、数据库)映射到公网。即使你在家里或外出时,也可以通过公网地址连接回本地运行的开发环境。

❤️以下是安装cpolar步骤:

官网在此:https://www.cpolar.com

使用一键脚本安装命令:

sudo curl https://get.cpolar.sh | sh

image-20250725104019896

安装完成后,执行下方命令查看cpolar服务状态:(如图所示即为正常启动)

sudo systemctl status cpolar

22e5adfaf290a17fc3384bb296055259

Cpolar安装和成功启动服务后,在浏览器上输入虚拟机主机IP加9200端口即:【http://ip:9200】访问Cpolar管理界面,使用Cpolar官网注册的账号登录,登录后即可看到cpolar web 配置界面,接下来在web 界面配置即可:

打开浏览器访问本地9200端口,使用cpolar账户密码登录即可,登录后即可对隧道进行管理。

8a6698b1bf26d64ba3645827fbfb1c29

6.配置公网地址

登录cpolar web UI管理界面后,点击左侧仪表盘的隧道管理——创建隧道:

  • 隧道名称:可自定义,本例使用了:spug,注意不要与已有的隧道名称重复
  • 协议:http
  • 本地地址:8086
  • 域名类型:随机域名
  • 地区:选择China Top

4857ef17967790e46027ae527a24dcf5

创建成功后,打开左侧在线隧道列表,可以看到刚刚通过创建隧道生成了公网地址,接下来就可以在其他电脑或者移动端设备(异地)上,使用地址访问。

ce120ec1aaab4b6cfd019dfbf9692ca8

访问成功。

92d31bb7af59081b05d7c7a0d0d8da73

7.保留固定公网地址

使用cpolar为其配置二级子域名(cpolar官网-安全的内网穿透工具 | 无需公网ip | 远程访问 | 搭建网站),该地址为固定地址,不会随机变化。

image-20250918151358733

点击左侧的预留,选择保留二级子域名,地区选择china Top,然后设置一个二级子域名名称,我使用的是spug,大家可以自定义。填写备注信息,点击保留。

8efe7b8a818de82d9ef2a23b8e12f5f5

登录cpolar web UI管理界面,点击左侧仪表盘的隧道管理——隧道列表,找到所要配置的隧道,点击右侧的编辑

944f2e52c97bda0ed240171d4be46805

修改隧道信息,将保留成功的二级子域名配置到隧道中

  • 域名类型:选择二级子域名
  • Sub Domain:填写保留成功的二级子域名
  • 地区: China Top

点击更新

ab3b9c6d27778da92c5d34d78cf10c4a

更新完成后,打开在线隧道列表,此时可以看到随机的公网地址已经发生变化,地址名称也变成了保留和固定的二级子域名名称。

e933526fbe8dc98996f299c204aa5d44

最后,我们使用固定的公网地址在任意设备的浏览器中访问,可以看到成功访问的页面,这样一个永久不会变化的二级子域名公网网址即设置好了。

16ceff01f4f48c3d41e6207d45a97113

总结

在传统运维模式中,Shell 或 Python 脚本虽能实现自动化,却普遍存在管理分散、执行不可视、权限混乱、审计困难等痛点,尤其在团队协作和业务规模扩大后,维护成本急剧上升。面对这一挑战,开源工具 Spug 提供了一套轻量、安全、直观的可视化运维解决方案。Spug 以 Web 界面为核心,将主机管理、批量命令执行、定时任务、应用发布等高频操作全面图形化,无需编写复杂脚本即可完成日常运维任务。其内置完善的多用户权限体系操作日志审计功能,确保每一次操作可追溯、可管控;同时支持主机组、任务模板、Git 集成等特性,显著提升部署效率与系统可靠性。更重要的是,Spug 部署极其简便——零外部依赖、单机即可运行,无论是个人开发者还是中小团队,都能快速上手,低成本实现 DevOps 自动化转型。通过本文实践,我们看到:真正的高效运维,不在于写更多脚本,而在于用更智能的方式管理执行过程。Spug 正是这样一座桥梁,帮助运维人员从“命令行苦力”转变为“流程设计者”,让自动化真正服务于效率与安全。

告别杂乱脚本,拥抱可视化未来——Spug,让运维更简单、更清晰、更可控。

感谢您对本篇文章的喜爱,有任何问题欢迎留言交流。cpolar官网-安全的内网穿透工具 | 无需公网ip | 远程访问 | 搭建网站

Share:

发表回复

目录

On Key

推荐文章