更新 package.json 启动命令,删除不再使用的部署相关文件和脚本,提升项目结构的简洁性和可维护性。
This commit is contained in:
108
.github/workflows/README.md
vendored
Normal file
108
.github/workflows/README.md
vendored
Normal 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
117
.github/workflows/deploy.yml
vendored
Normal 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 "无法获取日志"
|
||||
Reference in New Issue
Block a user