Sub-web 终极部署指南:Docker容器化与本地开发环境完整教程
2026-02-05 05:20:32作者:毕习沙Eudora
Sub-web是一个基于Vue.js和subconverter后端实现的配置自动生成工具,能够帮助用户快速生成订阅配置。作为GitHub加速计划的重要组件,sub-web部署简单且功能强大,支持多种部署方式。本文将详细介绍两种最实用的部署方法:Docker容器化部署和本地开发环境部署。🚀
📋 系统要求与准备工作
在开始部署之前,请确保您的系统满足以下基本要求:
Docker部署要求:
- Docker 23.0.4或更高版本
- 支持Linux、Windows或macOS系统
本地开发环境要求:
- Node.js 22.x版本
- Yarn 1.22.22或更高版本
- 现代Web浏览器
🐳 Docker容器化部署方法
Docker部署是最简单快捷的方式,适合生产环境使用。通过以下步骤即可完成部署:
快速启动Docker容器
使用官方镜像一键启动sub-web服务:
docker run -d -p 58080:80 --restart always --name subweb careywong/subweb:latest
自定义Docker镜像构建
如需修改代码或进行自定义配置,可以构建本地镜像:
# 克隆项目代码
git clone https://gitcode.com/gh_mirrors/su/sub-web
cd sub-web
# 构建自定义镜像
docker build -t subweb-local:latest .
docker run -d -p 58080:80 --restart always --name subweb subweb-local:latest
Docker Compose集成部署
项目提供了完整的Docker Compose配置,位于services/docker-compose.yaml,支持sub-web与MyUrls短链接服务的协同部署。
💻 本地开发环境部署
对于开发者或需要定制功能的用户,本地部署提供了更大的灵活性。
环境验证与依赖安装
首先验证Node.js和Yarn环境:
node -v
yarn -v
安装项目依赖:
yarn install
本地开发服务器启动
启动开发服务器进行测试:
yarn serve
启动后,在浏览器中访问 http://localhost:8080/ 即可使用sub-web服务。
🚀 生产环境部署指南
项目构建与打包
执行构建命令生成生产环境文件:
yarn build
构建完成后,会在项目根目录生成dist文件夹,包含所有静态资源。
Nginx服务器配置
将dist目录部署到Web服务器,以下是Nginx配置示例:
server {
listen 80;
server_name example.com;
root /var/www/http/sub-web/dist;
index index.html index.htm;
error_page 404 /index.html;
gzip on;
gzip_min_length 1k;
gzip_buffers 4 16k;
gzip_http_version 1.0;
gzip_comp_level 6;
gzip_types text/plain text/css text/javascript application/json application/javascript application/x-javascript application/xml;
gzip_vary on;
location ~* \.(css|js|png|jpg|jpeg|gif|gz|svg|mp4|ogg|ogv|webm|htc|xml|woff)$ {
access_log off;
add_header Cache-Control "public,max-age=30*24*3600";
}
}
🔧 核心配置文件说明
- 默认后端配置:src/views/Subconverter.vue 中的
defaultBackend参数 - 环境变量配置:通过.env文件管理后端服务地址
- 组件模块:src/components/ 包含所有UI组件
- 服务层:src/services/ 处理业务逻辑
📊 部署方案对比
| 部署方式 | 适用场景 | 优点 | 缺点 |
|---|---|---|---|
| Docker容器 | 生产环境 | 部署简单、环境隔离 | 定制性较差 |
| 本地开发 | 开发测试 | 灵活定制、调试方便 | 环境配置复杂 |
🎯 最佳实践建议
- Docker部署:推荐用于快速部署和稳定运行
- 本地开发:适合二次开发和功能定制
- 混合部署:开发阶段使用本地环境,生产环境使用Docker
通过本指南,您可以根据实际需求选择合适的部署方式,快速搭建属于自己的sub-web服务。无论是简单的Docker一键部署,还是完整的本地开发环境,都能满足不同用户的使用需求。✨
无论选择哪种部署方式,sub-web都能为您提供稳定可靠的配置生成服务,助力您的GitHub加速体验!
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0216
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0138
uni-appA cross-platform framework using Vue.jsJavaScript08
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
SwanLab⚡️SwanLab - an open-source, modern-design AI training tracking and visualization tool. Supports Cloud / Self-hosted use. Integrated with PyTorch / Transformers / LLaMA Factory / veRL/ Swift / Ultralytics / MMEngine / Keras etc.Python00
tiny-universe《大模型白盒子构建指南》:一个全手搓的Tiny-UniverseJupyter Notebook03
项目优选
收起
deepin linux kernel
C
32
16
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
471
465
Ascend Extension for PyTorch
Python
758
968
昇腾LLM分布式训练框架
Python
186
231
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
698
1.4 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
878
2.03 K
暂无描述
Dockerfile
780
5.08 K
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
70
22
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.04 K
271
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
2.08 K
216
