151 lines
3.9 KiB
Markdown
151 lines
3.9 KiB
Markdown
# Gitea Actions CI/CD 配置指南
|
||
|
||
## 整体流程
|
||
|
||
```
|
||
代码推送 → Gitea Actions自动构建 → SCP上传到宝塔服务器 → 完成!
|
||
```
|
||
|
||
## Gitea Secrets配置
|
||
|
||
在仓库 **Settings → Secrets** 中添加以下变量:
|
||
|
||
### 开发服务器
|
||
|
||
| 变量名 | 值示例 | 说明 |
|
||
| ------------------ | -------------------------------------------- | ------------- |
|
||
| `DEV_SERVER_IP` | `192.168.1.100` | 开发服务器IP |
|
||
| `DEV_SERVER_PATH` | `/www/wwwroot/test1.stnav.com/public/parten` | 部署路径 |
|
||
| `DEV_SSH_PASSWORD` | `你的SSH密码` | 服务器SSH密码 |
|
||
|
||
### 生产服务器
|
||
|
||
| 变量名 | 值示例 | 说明 |
|
||
| ------------------- | ----------------------------------------------- | ------------- |
|
||
| `PROD_SERVER_IP` | `192.168.1.101` | 生产服务器IP |
|
||
| `PROD_SERVER_PATH` | `/www/wwwroot/default/chaz_admin/public/parten` | 部署路径 |
|
||
| `PROD_SSH_PASSWORD` | `你的SSH密码` | 服务器SSH密码 |
|
||
|
||
## Gitea Actions Runner配置
|
||
|
||
确保你的Gitea Actions Runner标签包含 `ubuntu-latest`:
|
||
|
||
1. 登录Gitea管理员账户
|
||
2. 进入 **管理后台 → Actions → Runner**
|
||
3. 编辑Runner,添加标签:
|
||
- `ubuntu-latest`
|
||
- `ubuntu-24.04`
|
||
- `ubuntu-22.04`
|
||
|
||
## 宝塔面板准备工作
|
||
|
||
### 1. 确认SSH权限
|
||
|
||
在宝塔面板中确认SSH信息:
|
||
- **面板设置 → 面板账户** 中的SSH信息
|
||
- 或者在**安全 → SSH管理**中查看
|
||
|
||
### 2. 确保目录存在
|
||
|
||
在宝塔终端或SSH中创建部署目录:
|
||
|
||
```bash
|
||
# 开发服务器
|
||
mkdir -p /www/wwwroot/test1.stnav.com/public/parten
|
||
chmod -R 755 /www/wwwroot/test1.stnav.com/public/parten
|
||
|
||
# 生产服务器
|
||
mkdir -p /www/wwwroot/default/chaz_admin/public/parten
|
||
chmod -R 755 /www/wwwroot/default/chaz_admin/public/parten
|
||
```
|
||
|
||
## 宝塔防火墙配置
|
||
|
||
确保服务器的SSH端口(默认22)开放:
|
||
|
||
1. 宝塔面板 → 安全 → 防火墙
|
||
2. 放行22端口(或你自定义的SSH端口)
|
||
|
||
## 使用流程
|
||
|
||
### 开发环境(develop分支)
|
||
|
||
1. **推送代码**
|
||
```bash
|
||
git checkout develop
|
||
git add .
|
||
git commit -m "update"
|
||
git push origin develop
|
||
```
|
||
|
||
2. **自动构建和部署** - Gitea Actions自动执行全部流程
|
||
|
||
3. **验证** - 访问 `https://test1.stnav.com/parten`
|
||
|
||
### 生产环境(master分支)
|
||
|
||
1. **合并代码**
|
||
```bash
|
||
git checkout master
|
||
git merge develop
|
||
git push origin master
|
||
```
|
||
|
||
2. **自动构建和部署** - Gitea Actions自动执行全部流程
|
||
|
||
3. **验证** - 访问生产环境地址
|
||
|
||
## 宝塔站点配置(可选)
|
||
|
||
如果需要配置域名访问:
|
||
|
||
1. 宝塔面板 → 网站 → 添加站点
|
||
2. 填写域名(如:`test1.stnav.com`)
|
||
3. 根目录选择 `/www/wwwroot/test1.stnav.com/public`
|
||
4. 创建完成后,在站点设置中:
|
||
- 网站目录 → 运行目录改为 `parten`
|
||
- 或创建反向代理到 `http://127.0.0.1:端口/parten`
|
||
|
||
## 常见问题
|
||
|
||
### 1. Actions不执行
|
||
```
|
||
检查:
|
||
- Gitea Actions是否启用:管理后台 → Actions → 设置
|
||
- Runner是否在线
|
||
- Runner标签是否包含 ubuntu-latest
|
||
```
|
||
|
||
### 2. SSH连接失败
|
||
```
|
||
检查:
|
||
- 服务器IP是否正确
|
||
- SSH密码是否正确
|
||
- 防火墙是否放行22端口
|
||
- 宝塔SSH是否开启
|
||
```
|
||
|
||
### 3. 权限被拒绝
|
||
```
|
||
解决:
|
||
- 确认目标目录存在
|
||
- 检查目录权限:chmod 755 目录路径
|
||
- 确认SSH用户有写入权限
|
||
```
|
||
|
||
## 安全建议
|
||
|
||
⚠️ **重要提醒:**
|
||
- 生产服务器的密码建议定期更换
|
||
- 考虑使用受限的SSH用户
|
||
- 监控Actions日志,及时发现异常
|
||
|
||
## 优势
|
||
|
||
使用Gitea Actions的优势:
|
||
- ✅ 语法与GitHub Actions相同,易于理解
|
||
- ✅ 使用ubuntu系统,兼容性好
|
||
- ✅ 内置artifacts管理
|
||
- ✅ 支持并行任务
|
||
- ✅ 宝塔面板可视化服务器管理
|