更新 package.json 启动命令,删除不再使用的部署相关文件和脚本,提升项目结构的简洁性和可维护性。

This commit is contained in:
Alex-larget
2026-02-01 12:06:56 +08:00
parent bd23273190
commit 0078cb0e2a
11 changed files with 1448 additions and 403 deletions

108
.github/workflows/README.md vendored Normal file
View File

@@ -0,0 +1,108 @@
# GitHub Actions 自动化部署配置说明
## 📋 概述
本项目已配置 GitHub Actions 工作流,支持在推送代码到 `soul-content` 分支时自动部署到宝塔服务器。
## ✅ 项目兼容性
当前项目**完全支持** GitHub Actions 部署方式,因为:
- ✅ 使用 `standalone` 模式,构建产物独立完整
- ✅ 使用 pnpm 包管理器
- ✅ 已配置 PM2 启动方式(`node server.js`
- ✅ 端口配置为 3006
## 🔧 配置步骤
### 1. 在服务器上生成 SSH 密钥对
```bash
ssh root@42.194.232.22
ssh-keygen -t rsa -b 4096 -C "github-actions-deploy"
cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys
cat ~/.ssh/id_rsa # 复制私钥内容
```
### 2. 在 GitHub 仓库添加 Secrets
进入 GitHub 仓库:`Settings``Secrets and variables``Actions``New repository secret`
添加以下三个 Secrets
| Secret 名称 | 值 | 说明 |
|------------|-----|------|
| `SSH_HOST` | `42.194.232.22` | 服务器 IP |
| `SSH_USERNAME` | `root` | SSH 用户名 |
| `SSH_PRIVATE_KEY` | `-----BEGIN OPENSSH PRIVATE KEY-----...` | 服务器 SSH 私钥(完整内容) |
### 3. 修改工作流分支(如需要)
编辑 `.github/workflows/deploy.yml`,修改触发分支:
```yaml
on:
push:
branches:
- soul-content # 改为你的分支名
```
### 4. 提交并推送
```bash
git add .github/workflows/deploy.yml
git commit -m "添加 GitHub Actions 自动化部署"
git push origin soul-content
```
## 🚀 工作流程
1. **构建阶段**
- 安装 Node.js 22
- 安装 pnpm
- 安装项目依赖
- 执行 `pnpm build`(生成 standalone 输出)
2. **打包阶段**
- 复制 `.next/standalone` 内容
- 复制 `.next/static` 静态资源
- 复制 `public` 目录
- 复制 `ecosystem.config.cjs` PM2 配置
- 打包为 `deploy.tar.gz`
3. **部署阶段**
- 通过 SCP 上传到服务器 `/tmp/`
- SSH 连接到服务器
- 备份当前版本(可选)
- 解压到 `/www/wwwroot/soul`
- 重启 PM2 应用 `soul`
## 📊 与当前部署方式对比
| 特性 | GitHub Actions | deploy_soul.py |
|------|---------------|----------------|
| **触发方式** | 自动Push 代码) | 手动执行脚本 |
| **构建环境** | GitHub Ubuntu | 本地环境 |
| **构建速度** | 较慢(每次安装依赖) | 较快(本地缓存) |
| **适用场景** | 团队协作、CI/CD | 本地开发、快速部署 |
| **Windows 兼容** | ✅ 完美(云端构建) | ⚠️ 需处理符号链接 |
## ⚠️ 注意事项
1. **首次部署**:确保服务器上 `/www/wwwroot/soul` 目录存在且 PM2 已配置项目
2. **环境变量**:如果项目需要环境变量,需要在服务器上配置(宝塔面板或 `.env` 文件)
3. **数据库连接**:确保服务器能访问数据库
4. **构建时间**:首次构建可能需要 5-10 分钟后续会更快GitHub Actions 缓存)
## 🔍 查看部署日志
1. 在 GitHub 仓库点击 `Actions` 标签
2. 选择最新的工作流运行
3. 查看各步骤的详细日志
## 🆚 两种部署方式选择
- **使用 GitHub Actions**:适合团队协作,代码推送即自动部署
- **使用 deploy_soul.py**:适合本地快速测试,需要手动控制部署时机
两种方式可以并存,根据场景选择使用。

117
.github/workflows/deploy.yml vendored Normal file
View File

@@ -0,0 +1,117 @@
name: Deploy Next.js to Baota (Standalone)
on:
push:
branches:
- soul-content # 你的分支名
jobs:
build-and-deploy:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v3
- name: Set up Node.js
uses: actions/setup-node@v3
with:
node-version: 22
- name: Install pnpm
run: npm install -g pnpm
- name: Install dependencies
run: pnpm install
- name: Build project (standalone mode)
run: pnpm build
env:
NODE_ENV: production
- name: Package standalone output
run: |
# 创建临时打包目录
mkdir -p /tmp/deploy_package
# 复制 standalone 目录内容
cp -r .next/standalone/* /tmp/deploy_package/
# 复制 static 目录
mkdir -p /tmp/deploy_package/.next/static
cp -r .next/static/* /tmp/deploy_package/.next/static/
# 复制 public 目录
cp -r public /tmp/deploy_package/ 2>/dev/null || true
# 复制 PM2 配置文件
cp ecosystem.config.cjs /tmp/deploy_package/
# 打包
cd /tmp/deploy_package
tar -czf /tmp/deploy.tar.gz .
cd -
- name: Deploy to server via SCP
uses: appleboy/scp-action@master
with:
host: ${{ secrets.SSH_HOST }}
username: ${{ secrets.SSH_USERNAME }}
key: ${{ secrets.SSH_PRIVATE_KEY }}
source: "/tmp/deploy.tar.gz"
target: "/tmp/"
strip_components: 0
- name: Extract and restart on server
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.SSH_HOST }}
username: ${{ secrets.SSH_USERNAME }}
key: ${{ secrets.SSH_PRIVATE_KEY }}
script: |
cd /www/wwwroot/soul
# 备份当前版本(可选)
if [ -d ".next" ]; then
echo "备份当前版本..."
tar -czf /tmp/soul_backup_$(date +%Y%m%d_%H%M%S).tar.gz .next public ecosystem.config.cjs server.js package.json 2>/dev/null || true
fi
# 清理旧文件(保留 node_modules 如果存在)
rm -rf .next public ecosystem.config.cjs server.js package.json 2>/dev/null || true
# 解压新版本
echo "解压新版本..."
tar -xzf /tmp/deploy.tar.gz -C /www/wwwroot/soul
# 验证关键文件
if [ ! -f "server.js" ]; then
echo "错误: server.js 不存在,部署失败"
exit 1
fi
if [ ! -d ".next/static" ]; then
echo "警告: .next/static 目录不存在"
fi
# 设置权限
chmod +x server.js 2>/dev/null || true
# 重启 PM2 应用
echo "重启 PM2 应用..."
pm2 restart soul || pm2 start ecosystem.config.cjs || pm2 start server.js --name soul --env production
# 清理临时文件
rm -f /tmp/deploy.tar.gz
echo "部署完成!"
- name: Verify deployment
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.SSH_HOST }}
username: ${{ secrets.SSH_USERNAME }}
key: ${{ secrets.SSH_PRIVATE_KEY }}
script: |
pm2 list
pm2 logs soul --lines 10 --nostream || echo "无法获取日志"