@@ -7,27 +7,61 @@ jobs:
|
|||||||
deploy:
|
deploy:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
env:
|
env:
|
||||||
# 从组织级Secrets读取,不用在仓库重复配置
|
K3S_HOST: 121.37.117.181
|
||||||
K3S_HOST: ${{ secrets.K3S_HOST }}
|
|
||||||
APP_NAME: ${{ gitea.repo_name }}
|
APP_NAME: ${{ gitea.repo_name }}
|
||||||
|
# 替换为你的Gitea内置镜像仓库地址(必填)
|
||||||
|
REGISTRY: 116.204.74.41:3000/red-future
|
||||||
steps:
|
steps:
|
||||||
|
# 核心修改1:改用Gitea官方的checkout,避开GitHub
|
||||||
- name: 拉取代码
|
- name: 拉取代码
|
||||||
uses: actions/checkout@v4
|
uses: gitea/actions/checkout@v4
|
||||||
|
with:
|
||||||
|
# 增加超时配置,避免拉取代码超时
|
||||||
|
fetch-depth: 0
|
||||||
|
timeout-minutes: 10
|
||||||
|
|
||||||
|
# 1. 初始化 Docker Buildx
|
||||||
|
- name: Set up Docker Buildx
|
||||||
|
uses: docker/setup-buildx-action@v3
|
||||||
|
# 核心修改2:为Docker动作增加网络重试
|
||||||
|
env:
|
||||||
|
ACTIONS_RUNNER_DEBUG: true
|
||||||
|
with:
|
||||||
|
driver-opts: network=host
|
||||||
|
|
||||||
|
# 2. 登录镜像仓库(适配Gitea内置仓库,若用DockerHub则保留原配置)
|
||||||
|
- name: Login to Gitea Registry
|
||||||
|
uses: docker/login-action@v3
|
||||||
|
with:
|
||||||
|
registry: 116.204.74.41:3000
|
||||||
|
username: ${{ secrets.GITEA_USER }} # 需在Gitea配置该密钥(用户名)
|
||||||
|
password: ${{ secrets.GITEA_PWD }} # 需在Gitea配置该密钥(密码/令牌)
|
||||||
|
|
||||||
|
# 3. 构建+推送,启用缓存
|
||||||
|
- name: Build and push
|
||||||
|
uses: docker/build-push-action@v5
|
||||||
|
with:
|
||||||
|
context: .
|
||||||
|
push: true
|
||||||
|
tags: ${{ env.REGISTRY }}/${{ env.APP_NAME }}:${{ gitea.sha }}
|
||||||
|
# 缓存配置:推送到镜像仓库
|
||||||
|
cache-from: type=registry,ref=${{ env.REGISTRY }}/${{ env.APP_NAME }}:buildcache
|
||||||
|
cache-to: type=registry,ref=${{ env.REGISTRY }}/${{ env.APP_NAME }}:buildcache,mode=max
|
||||||
|
# 增加构建超时和重试
|
||||||
|
timeout: 300s
|
||||||
|
|
||||||
|
# 4. 修改后的SSH部署步骤(核心:上传仓库内deploy.yaml到K3s临时目录,解决路径不存在)
|
||||||
- name: SSH部署K3s
|
- name: SSH部署K3s
|
||||||
run: |
|
run: |
|
||||||
mkdir -p ~/.ssh
|
mkdir -p ~/.ssh
|
||||||
echo "${{ secrets.K3S_PEM_KEY }}" > k3s.pem
|
echo "${{ secrets.K3S_PEM_KEY }}" > k3s.pem
|
||||||
chmod 600 k3s.pem
|
chmod 600 k3s.pem
|
||||||
|
# 关键:上传仓库根目录的deploy.yaml到K3s服务器/tmp目录
|
||||||
# 关键1:上传当前仓库根目录的deploy.yaml到K3s服务器/tmp目录
|
scp -i k3s.pem -o StrictHostKeyChecking=no -o ConnectTimeout=10 ./deploy.yaml root@${K3S_HOST}:/tmp/
|
||||||
# 若deploy.yaml在仓库k8s子目录,改为 ./k8s/deploy.yaml
|
# 执行kubectl命令,指向临时文件+补充命名空间
|
||||||
scp -i k3s.pem -o StrictHostKeyChecking=no ./deploy.yaml root@${K3S_HOST}:/tmp/
|
ssh -i k3s.pem -o StrictHostKeyChecking=no -o ConnectTimeout=10 root@${K3S_HOST} << CMD
|
||||||
|
|
||||||
# 关键2:执行kubectl指向临时文件,补充命名空间避免找不到资源
|
|
||||||
ssh -i k3s.pem -o StrictHostKeyChecking=no root@${K3S_HOST} << CMD
|
|
||||||
kubectl apply -f /tmp/deploy.yaml
|
kubectl apply -f /tmp/deploy.yaml
|
||||||
kubectl rollout restart deployment ${APP_NAME} -n default
|
kubectl rollout restart deployment ${APP_NAME} -n default
|
||||||
# 可选:部署完成后删除临时文件,清理服务器
|
# 可选:清理临时文件
|
||||||
rm -f /tmp/deploy.yaml
|
rm -f /tmp/deploy.yaml
|
||||||
CMD
|
CMD
|
||||||
Reference in New Issue
Block a user