feat: 添加二次开发部署配置和文档
- 添加双 Git remote 配置指南 (GIT_GUIDE.md, GIT_WORKFLOW.md) - 添加 1Panel 环境部署配置 (docker-compose.1panel.yml, .env.1panel) - 添加自动化部署脚本 (deploy-complete.sh, deploy-dev.sh, deploy.sh) - 添加部署说明文档 (README_DEPLOY.md) - 配置端口 2080 映射 - 支持连接现有 1Panel Redis (1Panel-redis-S1KH)
This commit is contained in:
51
deploy/.env.1panel
Normal file
51
deploy/.env.1panel
Normal file
@@ -0,0 +1,51 @@
|
||||
# =============================================================================
|
||||
# Sub2API 环境配置 - 1Panel 环境
|
||||
# =============================================================================
|
||||
|
||||
# -----------------------------------------------------------------------------
|
||||
# Server Configuration
|
||||
# -----------------------------------------------------------------------------
|
||||
BIND_HOST=0.0.0.0
|
||||
SERVER_PORT=2080
|
||||
SERVER_MODE=release
|
||||
RUN_MODE=standard
|
||||
TZ=Asia/Shanghai
|
||||
|
||||
# -----------------------------------------------------------------------------
|
||||
# PostgreSQL Configuration (REQUIRED - 请修改密码!)
|
||||
# -----------------------------------------------------------------------------
|
||||
POSTGRES_USER=sub2api
|
||||
POSTGRES_PASSWORD=请修改为你的强密码
|
||||
POSTGRES_DB=sub2api
|
||||
|
||||
# -----------------------------------------------------------------------------
|
||||
# Redis Configuration - 使用你现有的 1Panel Redis
|
||||
# -----------------------------------------------------------------------------
|
||||
# 方式1:如果使用 Docker 网络连接,填写容器名
|
||||
REDIS_HOST=1Panel-redis-S1KH
|
||||
# 方式2:如果上面不行,使用宿主机 IP(需要你填写服务器的内网 IP)
|
||||
# REDIS_HOST=172.17.0.1
|
||||
REDIS_PORT=6379
|
||||
REDIS_PASSWORD=redis_bJFKDk
|
||||
REDIS_DB=1
|
||||
|
||||
# -----------------------------------------------------------------------------
|
||||
# Admin Account
|
||||
# -----------------------------------------------------------------------------
|
||||
ADMIN_EMAIL=oadmin
|
||||
ADMIN_PASSWORD=oadmin@123
|
||||
|
||||
# -----------------------------------------------------------------------------
|
||||
# JWT Configuration
|
||||
# -----------------------------------------------------------------------------
|
||||
# 使用下面的命令生成随机密钥:openssl rand -hex 32
|
||||
JWT_SECRET=1fb3a3533039e0d1ea693f0508bbffca44b7157370f11dfe33ce352a5f07039a
|
||||
JWT_EXPIRE_HOUR=24
|
||||
|
||||
# -----------------------------------------------------------------------------
|
||||
# Gemini OAuth (可选 - 如果不使用 Gemini 可以忽略)
|
||||
# -----------------------------------------------------------------------------
|
||||
GEMINI_OAUTH_CLIENT_ID=
|
||||
GEMINI_OAUTH_CLIENT_SECRET=
|
||||
GEMINI_OAUTH_SCOPES=
|
||||
GEMINI_QUOTA_POLICY=
|
||||
136
deploy/README_DEPLOY.md
Normal file
136
deploy/README_DEPLOY.md
Normal file
@@ -0,0 +1,136 @@
|
||||
# Sub2API 部署指南 - 端口 2080
|
||||
|
||||
## 快速部署(推荐)
|
||||
|
||||
### 1. 上传文件到服务器
|
||||
|
||||
将 `deploy` 目录上传到服务器的 `/opt/sub2api`
|
||||
|
||||
```bash
|
||||
# 在服务器上创建目录
|
||||
mkdir -p /opt/sub2api
|
||||
```
|
||||
|
||||
### 2. 运行自动部署脚本
|
||||
|
||||
```bash
|
||||
cd /opt/sub2api
|
||||
chmod +x deploy.sh
|
||||
bash deploy.sh
|
||||
```
|
||||
|
||||
脚本会自动完成:
|
||||
- ✅ 生成安全的密码和密钥
|
||||
- ✅ 创建配置文件
|
||||
- ✅ 拉取 Docker 镜像
|
||||
- ✅ 启动服务
|
||||
|
||||
### 3. 访问系统
|
||||
|
||||
浏览器打开: `http://你的服务器IP:2080`
|
||||
|
||||
默认账号:
|
||||
- 邮箱: `admin@example.com`
|
||||
- 密码: `admin123`
|
||||
|
||||
---
|
||||
|
||||
## 手动部署
|
||||
|
||||
如果自动脚本失败,可以手动部署:
|
||||
|
||||
```bash
|
||||
cd /opt/sub2api
|
||||
|
||||
# 1. 复制配置文件
|
||||
cp docker-compose.2080.yml docker-compose.yml
|
||||
cp .env.2080 .env
|
||||
|
||||
# 2. 生成密钥
|
||||
sed -i "s/POSTGRES_PASSWORD=.*/POSTGRES_PASSWORD=$(openssl rand -base64 24)/" .env
|
||||
sed -i "s/JWT_SECRET=.*/JWT_SECRET=$(openssl rand -hex 32)/" .env
|
||||
|
||||
# 3. 启动服务
|
||||
docker-compose pull
|
||||
docker-compose up -d
|
||||
|
||||
# 4. 查看日志
|
||||
docker-compose logs -f
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
## 配置说明
|
||||
|
||||
### 端口映射
|
||||
- 宿主机端口: `2080`
|
||||
- 容器内端口: `8080`
|
||||
|
||||
### Redis 连接
|
||||
- 使用现有的 1Panel Redis: `1Panel-redis-S1KH`
|
||||
- 端口: `6379`
|
||||
- 密码: `redis_bJFKDk`
|
||||
- 数据库: `1` (避免与其他应用冲突)
|
||||
|
||||
### PostgreSQL
|
||||
- 自动创建独立的 PostgreSQL 容器
|
||||
- 数据持久化在 Docker volume 中
|
||||
|
||||
---
|
||||
|
||||
## 常用命令
|
||||
|
||||
```bash
|
||||
# 查看服务状态
|
||||
docker-compose ps
|
||||
|
||||
# 查看日志
|
||||
docker-compose logs -f
|
||||
|
||||
# 重启服务
|
||||
docker-compose restart
|
||||
|
||||
# 停止服务
|
||||
docker-compose down
|
||||
|
||||
# 更新到最新版本
|
||||
docker-compose pull
|
||||
docker-compose up -d
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
## 故障排查
|
||||
|
||||
### Redis 连接失败
|
||||
|
||||
如果日志显示 Redis 连接失败,尝试修改 `docker-compose.yml`:
|
||||
|
||||
将:
|
||||
```yaml
|
||||
- REDIS_HOST=host.docker.internal
|
||||
```
|
||||
|
||||
改为:
|
||||
```yaml
|
||||
- REDIS_HOST=172.17.0.1
|
||||
```
|
||||
|
||||
然后重启:
|
||||
```bash
|
||||
docker-compose down
|
||||
docker-compose up -d
|
||||
```
|
||||
|
||||
### 查看详细日志
|
||||
|
||||
```bash
|
||||
# 只看 sub2api 日志
|
||||
docker-compose logs sub2api
|
||||
|
||||
# 只看 PostgreSQL 日志
|
||||
docker-compose logs postgres
|
||||
|
||||
# 实时查看最新 50 行日志
|
||||
docker-compose logs -f --tail=50
|
||||
```
|
||||
221
deploy/deploy-complete.sh
Normal file
221
deploy/deploy-complete.sh
Normal file
@@ -0,0 +1,221 @@
|
||||
#!/bin/bash
|
||||
|
||||
# Sub2API 完整部署脚本 - 双 Git Remote 配置
|
||||
# 官方仓库: https://github.com/Wei-Shaw/sub2api.git
|
||||
# 你的仓库: https://git.586vip.cn/oadmin/sub2api.git
|
||||
|
||||
set -e
|
||||
|
||||
echo "=========================================="
|
||||
echo " Sub2API 二次开发环境部署"
|
||||
echo " 端口: 2080"
|
||||
echo " 双 Remote Git 配置"
|
||||
echo "=========================================="
|
||||
echo ""
|
||||
|
||||
# 检查是否已经存在项目目录
|
||||
if [ -d "/opt/sub2api-dev" ]; then
|
||||
echo "⚠️ 目录 /opt/sub2api-dev 已存在"
|
||||
read -p "是否删除并重新部署?(y/N): " confirm
|
||||
if [[ $confirm == [yY] ]]; then
|
||||
rm -rf /opt/sub2api-dev
|
||||
else
|
||||
echo "❌ 取消部署"
|
||||
exit 1
|
||||
fi
|
||||
fi
|
||||
|
||||
cd /opt
|
||||
|
||||
# ===================================
|
||||
# 1. 克隆官方仓库
|
||||
# ===================================
|
||||
echo "📥 克隆官方仓库..."
|
||||
git clone https://github.com/Wei-Shaw/sub2api.git sub2api-dev
|
||||
cd sub2api-dev
|
||||
|
||||
echo "✅ 官方仓库克隆完成"
|
||||
echo ""
|
||||
|
||||
# ===================================
|
||||
# 2. 配置双 Remote
|
||||
# ===================================
|
||||
echo "🔧 配置 Git Remote..."
|
||||
|
||||
# 将 origin 改名为 upstream(官方仓库)
|
||||
git remote rename origin upstream
|
||||
|
||||
# 添加你的仓库为 origin
|
||||
git remote add origin https://git.586vip.cn/oadmin/sub2api.git
|
||||
|
||||
# 显示配置结果
|
||||
echo "✅ Git Remote 配置完成:"
|
||||
git remote -v
|
||||
echo ""
|
||||
|
||||
# ===================================
|
||||
# 3. 创建并切换到 main 分支
|
||||
# ===================================
|
||||
echo "🌿 创建 main 分支..."
|
||||
git checkout -b main
|
||||
|
||||
echo "✅ 当前分支: $(git branch --show-current)"
|
||||
echo ""
|
||||
|
||||
# ===================================
|
||||
# 4. 首次推送到你的仓库
|
||||
# ===================================
|
||||
echo "📤 推送到你的仓库..."
|
||||
git push -u origin main
|
||||
|
||||
echo "✅ 代码已推送到: https://git.586vip.cn/oadmin/sub2api.git"
|
||||
echo ""
|
||||
|
||||
# ===================================
|
||||
# 5. 配置部署文件
|
||||
# ===================================
|
||||
echo "📝 配置部署文件..."
|
||||
|
||||
cd deploy
|
||||
|
||||
# 创建生产环境 docker-compose 配置
|
||||
cat > docker-compose.prod.yml << 'EOF'
|
||||
services:
|
||||
sub2api:
|
||||
image: weishaw/sub2api:latest
|
||||
container_name: sub2api
|
||||
restart: unless-stopped
|
||||
ports:
|
||||
- "2080:8080"
|
||||
volumes:
|
||||
- ./data:/app/data
|
||||
environment:
|
||||
- AUTO_SETUP=true
|
||||
- SERVER_HOST=0.0.0.0
|
||||
- SERVER_PORT=8080
|
||||
- SERVER_MODE=release
|
||||
- DATABASE_HOST=postgres
|
||||
- DATABASE_PORT=5432
|
||||
- DATABASE_USER=sub2api
|
||||
- DATABASE_PASSWORD=${POSTGRES_PASSWORD}
|
||||
- DATABASE_DBNAME=sub2api
|
||||
- DATABASE_SSLMODE=disable
|
||||
- REDIS_HOST=host.docker.internal
|
||||
- REDIS_PORT=6379
|
||||
- REDIS_PASSWORD=redis_bJFKDk
|
||||
- REDIS_DB=1
|
||||
- ADMIN_EMAIL=${ADMIN_EMAIL}
|
||||
- ADMIN_PASSWORD=${ADMIN_PASSWORD}
|
||||
- JWT_SECRET=${JWT_SECRET}
|
||||
- TZ=Asia/Shanghai
|
||||
depends_on:
|
||||
- postgres
|
||||
extra_hosts:
|
||||
- "host.docker.internal:host-gateway"
|
||||
|
||||
postgres:
|
||||
image: postgres:18-alpine
|
||||
container_name: sub2api-postgres
|
||||
restart: unless-stopped
|
||||
volumes:
|
||||
- postgres_data:/var/lib/postgresql/data
|
||||
environment:
|
||||
- POSTGRES_USER=sub2api
|
||||
- POSTGRES_PASSWORD=${POSTGRES_PASSWORD}
|
||||
- POSTGRES_DB=sub2api
|
||||
- TZ=Asia/Shanghai
|
||||
healthcheck:
|
||||
test: ["CMD-SHELL", "pg_isready -U sub2api"]
|
||||
interval: 10s
|
||||
timeout: 5s
|
||||
retries: 5
|
||||
|
||||
volumes:
|
||||
postgres_data:
|
||||
EOF
|
||||
|
||||
echo "✅ docker-compose.prod.yml 已创建"
|
||||
|
||||
# 创建 .env 文件
|
||||
if [ ! -f ".env" ]; then
|
||||
echo "🔐 生成配置文件..."
|
||||
|
||||
POSTGRES_PASS=$(openssl rand -base64 24)
|
||||
JWT_KEY=$(openssl rand -hex 32)
|
||||
|
||||
cat > .env << EOF
|
||||
# PostgreSQL 配置
|
||||
POSTGRES_USER=sub2api
|
||||
POSTGRES_PASSWORD=${POSTGRES_PASS}
|
||||
POSTGRES_DB=sub2api
|
||||
|
||||
# 管理员账号
|
||||
ADMIN_EMAIL=admin@example.com
|
||||
ADMIN_PASSWORD=admin123
|
||||
|
||||
# JWT 配置
|
||||
JWT_SECRET=${JWT_KEY}
|
||||
JWT_EXPIRE_HOUR=24
|
||||
|
||||
# 其他配置
|
||||
TZ=Asia/Shanghai
|
||||
SERVER_MODE=release
|
||||
RUN_MODE=standard
|
||||
EOF
|
||||
|
||||
echo "✅ .env 文件已创建"
|
||||
echo ""
|
||||
echo "🔑 生成的密钥(请保存):"
|
||||
echo " PostgreSQL 密码: ${POSTGRES_PASS}"
|
||||
echo " JWT Secret: ${JWT_KEY}"
|
||||
echo ""
|
||||
fi
|
||||
|
||||
# ===================================
|
||||
# 6. 启动 Docker 服务
|
||||
# ===================================
|
||||
echo "🐳 拉取 Docker 镜像..."
|
||||
docker-compose -f docker-compose.prod.yml pull
|
||||
|
||||
echo ""
|
||||
echo "🚀 启动服务..."
|
||||
docker-compose -f docker-compose.prod.yml up -d
|
||||
|
||||
echo ""
|
||||
echo "⏳ 等待服务启动..."
|
||||
sleep 15
|
||||
|
||||
# ===================================
|
||||
# 7. 显示部署结果
|
||||
# ===================================
|
||||
echo ""
|
||||
echo "📊 服务状态:"
|
||||
docker-compose -f docker-compose.prod.yml ps
|
||||
|
||||
echo ""
|
||||
echo "=========================================="
|
||||
echo " ✅ 部署完成!"
|
||||
echo "=========================================="
|
||||
echo ""
|
||||
echo "🌐 访问信息:"
|
||||
echo " URL: http://$(hostname -I | awk '{print $1}'):2080"
|
||||
echo " 管理员: admin@example.com / admin123"
|
||||
echo ""
|
||||
echo "📋 Git 配置:"
|
||||
echo " 官方仓库 (upstream): https://github.com/Wei-Shaw/sub2api.git"
|
||||
echo " 你的仓库 (origin): https://git.586vip.cn/oadmin/sub2api.git"
|
||||
echo " 当前分支: main"
|
||||
echo ""
|
||||
echo "🔄 同步官方更新:"
|
||||
echo " cd /opt/sub2api-dev"
|
||||
echo " git fetch upstream"
|
||||
echo " git merge upstream/main"
|
||||
echo " git push origin main"
|
||||
echo ""
|
||||
echo "📝 常用命令:"
|
||||
echo " 查看日志: cd /opt/sub2api-dev/deploy && docker-compose -f docker-compose.prod.yml logs -f"
|
||||
echo " 重启服务: docker-compose -f docker-compose.prod.yml restart"
|
||||
echo " 停止服务: docker-compose -f docker-compose.prod.yml down"
|
||||
echo ""
|
||||
echo "🎉 访问 http://$(hostname -I | awk '{print $1}'):2080 开始使用!"
|
||||
echo ""
|
||||
120
deploy/deploy-dev.sh
Normal file
120
deploy/deploy-dev.sh
Normal file
@@ -0,0 +1,120 @@
|
||||
#!/bin/bash
|
||||
|
||||
# Sub2API 二次开发部署脚本
|
||||
# 使用方法: bash deploy-dev.sh
|
||||
|
||||
set -e
|
||||
|
||||
echo "====================================="
|
||||
echo " Sub2API 二开版本部署"
|
||||
echo " 端口: 2080"
|
||||
echo "====================================="
|
||||
echo ""
|
||||
|
||||
# 检查是否在 Git 仓库中
|
||||
if [ ! -d ".git" ]; then
|
||||
echo "❌ 错误: 当前目录不是 Git 仓库"
|
||||
echo "请在项目根目录运行此脚本"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "📦 当前 Git 信息:"
|
||||
echo " 分支: $(git branch --show-current)"
|
||||
echo " 最新提交: $(git log -1 --oneline)"
|
||||
echo ""
|
||||
|
||||
# 进入 deploy 目录
|
||||
cd deploy
|
||||
|
||||
# 检查配置文件
|
||||
if [ ! -f "docker-compose.prod.yml" ]; then
|
||||
echo "📝 创建生产环境配置..."
|
||||
cp docker-compose.yml docker-compose.prod.yml
|
||||
|
||||
# 修改端口为 2080
|
||||
sed -i 's/\${SERVER_PORT:-8080}/2080/' docker-compose.prod.yml
|
||||
|
||||
# 添加 extra_hosts 配置(连接宿主机 Redis)
|
||||
if ! grep -q "extra_hosts" docker-compose.prod.yml; then
|
||||
sed -i '/depends_on:/i\ extra_hosts:\n - "host.docker.internal:host-gateway"' docker-compose.prod.yml
|
||||
fi
|
||||
|
||||
# 修改 Redis 配置
|
||||
sed -i 's/REDIS_HOST=redis/REDIS_HOST=host.docker.internal/' docker-compose.prod.yml
|
||||
sed -i 's/REDIS_PASSWORD=\${REDIS_PASSWORD:-}/REDIS_PASSWORD=redis_bJFKDk/' docker-compose.prod.yml
|
||||
sed -i 's/REDIS_DB=\${REDIS_DB:-0}/REDIS_DB=1/' docker-compose.prod.yml
|
||||
|
||||
echo "✅ docker-compose.prod.yml 已创建"
|
||||
fi
|
||||
|
||||
# 创建 .env 文件
|
||||
if [ ! -f ".env" ]; then
|
||||
echo "🔐 生成配置文件..."
|
||||
|
||||
cat > .env << EOF
|
||||
# PostgreSQL 配置
|
||||
POSTGRES_USER=sub2api
|
||||
POSTGRES_PASSWORD=$(openssl rand -base64 24)
|
||||
POSTGRES_DB=sub2api
|
||||
|
||||
# 管理员账号
|
||||
ADMIN_EMAIL=admin@example.com
|
||||
ADMIN_PASSWORD=admin123
|
||||
|
||||
# JWT 配置
|
||||
JWT_SECRET=$(openssl rand -hex 32)
|
||||
JWT_EXPIRE_HOUR=24
|
||||
|
||||
# 其他配置
|
||||
TZ=Asia/Shanghai
|
||||
SERVER_MODE=release
|
||||
RUN_MODE=standard
|
||||
EOF
|
||||
|
||||
echo "✅ .env 文件已创建"
|
||||
echo ""
|
||||
echo "📋 生成的配置(请保存):"
|
||||
cat .env | grep -E "POSTGRES_PASSWORD|JWT_SECRET"
|
||||
echo ""
|
||||
else
|
||||
echo "⚠️ .env 已存在,跳过创建"
|
||||
fi
|
||||
|
||||
# 拉取镜像
|
||||
echo ""
|
||||
echo "📥 拉取 Docker 镜像..."
|
||||
docker-compose -f docker-compose.prod.yml pull
|
||||
|
||||
# 启动服务
|
||||
echo ""
|
||||
echo "🚀 启动服务..."
|
||||
docker-compose -f docker-compose.prod.yml up -d
|
||||
|
||||
# 等待启动
|
||||
echo ""
|
||||
echo "⏳ 等待服务启动..."
|
||||
sleep 10
|
||||
|
||||
# 显示状态
|
||||
echo ""
|
||||
echo "📊 服务状态:"
|
||||
docker-compose -f docker-compose.prod.yml ps
|
||||
|
||||
echo ""
|
||||
echo "====================================="
|
||||
echo " ✅ 部署完成!"
|
||||
echo "====================================="
|
||||
echo ""
|
||||
echo "📝 访问信息:"
|
||||
echo " URL: http://$(hostname -I | awk '{print $1}'):2080"
|
||||
echo " 管理员: admin@example.com / admin123"
|
||||
echo ""
|
||||
echo "📋 常用命令:"
|
||||
echo " 查看日志: docker-compose -f docker-compose.prod.yml logs -f"
|
||||
echo " 重启服务: docker-compose -f docker-compose.prod.yml restart"
|
||||
echo " 停止服务: docker-compose -f docker-compose.prod.yml down"
|
||||
echo ""
|
||||
echo "🔄 同步官方更新:"
|
||||
echo " git fetch upstream"
|
||||
echo " git merge upstream/main"
|
||||
echo ""
|
||||
104
deploy/deploy.sh
Normal file
104
deploy/deploy.sh
Normal file
@@ -0,0 +1,104 @@
|
||||
#!/bin/bash
|
||||
|
||||
# Sub2API 自动部署脚本 - 端口 2080
|
||||
# 使用方法: bash deploy.sh
|
||||
|
||||
set -e
|
||||
|
||||
echo "====================================="
|
||||
echo " Sub2API 自动部署脚本"
|
||||
echo " 端口: 2080"
|
||||
echo "====================================="
|
||||
echo ""
|
||||
|
||||
# 检查是否在正确的目录
|
||||
if [ ! -f "docker-compose.2080.yml" ]; then
|
||||
echo "❌ 错误: 请在包含 docker-compose.2080.yml 的目录中运行此脚本"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# 检查 Docker 是否安装
|
||||
if ! command -v docker &> /dev/null; then
|
||||
echo "❌ Docker 未安装,请先安装 Docker"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if ! command -v docker-compose &> /dev/null; then
|
||||
echo "❌ Docker Compose 未安装,请先安装 Docker Compose"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
echo "✅ Docker 环境检查通过"
|
||||
echo ""
|
||||
|
||||
# 复制配置文件
|
||||
if [ ! -f ".env" ]; then
|
||||
echo "📝 创建配置文件..."
|
||||
cp .env.2080 .env
|
||||
|
||||
# 生成随机密码和密钥
|
||||
echo "🔐 生成安全密钥..."
|
||||
POSTGRES_PASS=$(openssl rand -base64 24)
|
||||
JWT_KEY=$(openssl rand -hex 32)
|
||||
|
||||
# 更新 .env 文件
|
||||
sed -i "s/POSTGRES_PASSWORD=.*/POSTGRES_PASSWORD=${POSTGRES_PASS}/" .env
|
||||
sed -i "s/JWT_SECRET=.*/JWT_SECRET=${JWT_KEY}/" .env
|
||||
|
||||
echo "✅ 配置文件已创建: .env"
|
||||
echo ""
|
||||
echo "📋 生成的密码(请保存):"
|
||||
echo " PostgreSQL 密码: ${POSTGRES_PASS}"
|
||||
echo ""
|
||||
else
|
||||
echo "⚠️ .env 文件已存在,跳过创建"
|
||||
echo ""
|
||||
fi
|
||||
|
||||
# 复制 docker-compose 文件
|
||||
if [ ! -f "docker-compose.yml" ]; then
|
||||
echo "📝 创建 docker-compose.yml..."
|
||||
cp docker-compose.2080.yml docker-compose.yml
|
||||
echo "✅ docker-compose.yml 已创建"
|
||||
echo ""
|
||||
fi
|
||||
|
||||
# 拉取镜像
|
||||
echo "📥 拉取 Docker 镜像..."
|
||||
docker-compose pull
|
||||
|
||||
# 启动服务
|
||||
echo ""
|
||||
echo "🚀 启动服务..."
|
||||
docker-compose up -d
|
||||
|
||||
# 等待服务启动
|
||||
echo ""
|
||||
echo "⏳ 等待服务启动..."
|
||||
sleep 10
|
||||
|
||||
# 检查服务状态
|
||||
echo ""
|
||||
echo "📊 服务状态:"
|
||||
docker-compose ps
|
||||
|
||||
echo ""
|
||||
echo "====================================="
|
||||
echo " ✅ 部署完成!"
|
||||
echo "====================================="
|
||||
echo ""
|
||||
echo "📝 访问信息:"
|
||||
echo " URL: http://$(hostname -I | awk '{print $1}'):2080"
|
||||
echo " 管理员邮箱: admin@example.com"
|
||||
echo " 管理员密码: admin123"
|
||||
echo ""
|
||||
echo "⚠️ 安全建议:"
|
||||
echo " 1. 登录后立即修改管理员密码"
|
||||
echo " 2. 如需修改配置,编辑 .env 文件后执行: docker-compose restart"
|
||||
echo ""
|
||||
echo "📋 常用命令:"
|
||||
echo " 查看日志: docker-compose logs -f"
|
||||
echo " 重启服务: docker-compose restart"
|
||||
echo " 停止服务: docker-compose down"
|
||||
echo ""
|
||||
echo "🎉 部署完成!请在浏览器中访问上述 URL"
|
||||
111
deploy/docker-compose.1panel.yml
Normal file
111
deploy/docker-compose.1panel.yml
Normal file
@@ -0,0 +1,111 @@
|
||||
# =============================================================================
|
||||
# Sub2API Docker Compose - 1Panel 环境配置
|
||||
# =============================================================================
|
||||
# 此配置文件适用于已有 1Panel 环境,复用现有 Redis
|
||||
# =============================================================================
|
||||
|
||||
services:
|
||||
# ===========================================================================
|
||||
# Sub2API Application
|
||||
# ===========================================================================
|
||||
sub2api:
|
||||
image: weishaw/sub2api:latest
|
||||
container_name: sub2api
|
||||
restart: unless-stopped
|
||||
ulimits:
|
||||
nofile:
|
||||
soft: 100000
|
||||
hard: 100000
|
||||
ports:
|
||||
- "${BIND_HOST:-0.0.0.0}:${SERVER_PORT:-8080}:8080"
|
||||
volumes:
|
||||
- sub2api_data:/app/data
|
||||
environment:
|
||||
# Auto Setup
|
||||
- AUTO_SETUP=true
|
||||
|
||||
# Server Configuration
|
||||
- SERVER_HOST=0.0.0.0
|
||||
- SERVER_PORT=8080
|
||||
- SERVER_MODE=${SERVER_MODE:-release}
|
||||
- RUN_MODE=${RUN_MODE:-standard}
|
||||
|
||||
# Database Configuration
|
||||
- DATABASE_HOST=postgres
|
||||
- DATABASE_PORT=5432
|
||||
- DATABASE_USER=${POSTGRES_USER:-sub2api}
|
||||
- DATABASE_PASSWORD=${POSTGRES_PASSWORD:?POSTGRES_PASSWORD is required}
|
||||
- DATABASE_DBNAME=${POSTGRES_DB:-sub2api}
|
||||
- DATABASE_SSLMODE=disable
|
||||
|
||||
# Redis Configuration - 使用外部 Redis
|
||||
- REDIS_HOST=${REDIS_HOST}
|
||||
- REDIS_PORT=${REDIS_PORT:-6379}
|
||||
- REDIS_PASSWORD=${REDIS_PASSWORD}
|
||||
- REDIS_DB=${REDIS_DB:-0}
|
||||
|
||||
# Admin Account
|
||||
- ADMIN_EMAIL=${ADMIN_EMAIL:-admin@sub2api.local}
|
||||
- ADMIN_PASSWORD=${ADMIN_PASSWORD:-}
|
||||
|
||||
# JWT Configuration
|
||||
- JWT_SECRET=${JWT_SECRET:-}
|
||||
- JWT_EXPIRE_HOUR=${JWT_EXPIRE_HOUR:-24}
|
||||
|
||||
# Timezone
|
||||
- TZ=${TZ:-Asia/Shanghai}
|
||||
|
||||
# Gemini OAuth (可选)
|
||||
- GEMINI_OAUTH_CLIENT_ID=${GEMINI_OAUTH_CLIENT_ID:-}
|
||||
- GEMINI_OAUTH_CLIENT_SECRET=${GEMINI_OAUTH_CLIENT_SECRET:-}
|
||||
- GEMINI_OAUTH_SCOPES=${GEMINI_OAUTH_SCOPES:-}
|
||||
- GEMINI_QUOTA_POLICY=${GEMINI_QUOTA_POLICY:-}
|
||||
depends_on:
|
||||
postgres:
|
||||
condition: service_healthy
|
||||
# 使用 host 网络模式以访问宿主机上的 1Panel Redis
|
||||
# 或者可以使用 extra_hosts 添加到 1Panel 网络
|
||||
network_mode: bridge
|
||||
extra_hosts:
|
||||
- "host.docker.internal:host-gateway"
|
||||
healthcheck:
|
||||
test: ["CMD", "curl", "-f", "http://localhost:8080/health"]
|
||||
interval: 30s
|
||||
timeout: 10s
|
||||
retries: 3
|
||||
start_period: 30s
|
||||
|
||||
# ===========================================================================
|
||||
# PostgreSQL Database
|
||||
# ===========================================================================
|
||||
postgres:
|
||||
image: postgres:18-alpine
|
||||
container_name: sub2api-postgres
|
||||
restart: unless-stopped
|
||||
ulimits:
|
||||
nofile:
|
||||
soft: 100000
|
||||
hard: 100000
|
||||
volumes:
|
||||
- postgres_data:/var/lib/postgresql/data
|
||||
environment:
|
||||
- POSTGRES_USER=${POSTGRES_USER:-sub2api}
|
||||
- POSTGRES_PASSWORD=${POSTGRES_PASSWORD:?POSTGRES_PASSWORD is required}
|
||||
- POSTGRES_DB=${POSTGRES_DB:-sub2api}
|
||||
- TZ=${TZ:-Asia/Shanghai}
|
||||
network_mode: bridge
|
||||
healthcheck:
|
||||
test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER:-sub2api} -d ${POSTGRES_DB:-sub2api}"]
|
||||
interval: 10s
|
||||
timeout: 5s
|
||||
retries: 5
|
||||
start_period: 10s
|
||||
|
||||
# =============================================================================
|
||||
# Volumes
|
||||
# =============================================================================
|
||||
volumes:
|
||||
sub2api_data:
|
||||
driver: local
|
||||
postgres_data:
|
||||
driver: local
|
||||
Reference in New Issue
Block a user