This commit is contained in:
@@ -15,9 +15,9 @@
|
||||
- `REGISTRY_URL`:镜像仓库域名,例如 `registry.example.com`。
|
||||
- `REGISTRY_USERNAME` / `REGISTRY_PASSWORD`:镜像仓库凭据;若 Registry 允许匿名访问,可留空,本 workflow 会自动跳过登录步骤。
|
||||
- `IMAGE_NAME`:镜像名称,默认为 `jt808-server`。
|
||||
- `DEPLOY_HOST` / `DEPLOY_PORT`:SSH 目标主机地址与端口(22)。
|
||||
- `DEPLOY_USER`:SSH 用户名。
|
||||
- `DEPLOY_PRIVATE_KEY`:SSH 私钥,目标主机需部署对应的公钥。
|
||||
- `CLONE_TOKEN`:可选;**私有仓库**用来 `git clone` 的访问令牌(推荐使用一个只读 Token)。若仓库公开或 Runner 本身有访问权限可不配。
|
||||
|
||||
> 你提到“仓库/Runner/部署都在同一台服务器”时,本仓库的 workflow 默认采用**本机直接部署**(不走 SSH),因此不需要 `DEPLOY_*` 相关 Secrets。
|
||||
|
||||
## 工作流 `.gitea/workflows/ci-deploy.yml`
|
||||
|
||||
@@ -32,15 +32,15 @@ on:
|
||||
|
||||
> Gitea Actions 使用 `uses: https://github.com/...` 语法来引用 GitHub 上已有的 Action,因此 workflow 中的 Action 即使不是 Gitea 官方的也能被 Runner 下载与执行。
|
||||
|
||||
> 如果你希望 **完全不依赖 GitHub**,可以把 `uses` 指向 `https://gitea.com/actions/...` 的镜像仓库(如 `checkout`),并尽量用 `run:` + `docker` 命令完成构建与推送。
|
||||
> 如果你希望 **完全不依赖外部 Action**,可以像本仓库当前 workflow 一样:用 `run:` + `git clone` + `docker` 命令完成全部流程(不再使用 `checkout`)。
|
||||
|
||||
- **构建阶段**:
|
||||
- `https://gitea.com/actions/checkout@v4` 拉取代码。
|
||||
- 使用 `git clone` 拉取代码(可选 `CLONE_TOKEN` 访问私有仓库)。
|
||||
- 使用 `maven:3.9.9-eclipse-temurin-17` 容器在 CI 中执行 `mvn -B clean package -DskipTests` 生成可执行 Jar。
|
||||
- **镜像阶段**:
|
||||
- 直接使用 `docker build` / `docker push` 构建并推送镜像:标签格式 `${REGISTRY_URL}/${IMAGE_NAME}:${short-commit}`,通过 `git rev-parse --short HEAD` 动态生成。
|
||||
- **部署阶段**:
|
||||
- `https://gitea.com/appleboy/ssh-action@v0.1.5` 登录目标主机,执行 `docker pull`、`docker stop`、`docker rm`、`docker run` 的操作,始终以 `jt808-server` 名称运行容器并暴露 `8080`/`20048`。
|
||||
- 同机部署:在 Runner 所在服务器直接执行 `docker pull`、`docker stop`、`docker rm`、`docker run`,始终以 `jt808-server` 名称运行容器并暴露 `8080`/`20048`。
|
||||
|
||||
## 目标服务器要求
|
||||
|
||||
|
||||
Reference in New Issue
Block a user