dockerfile
All checks were successful
全局K3s部署 / deploy (push) Successful in 6s

This commit is contained in:
2026-05-23 17:12:26 +08:00
parent a8fb18a3e5
commit 61a6c143ad

View File

@@ -7,31 +7,28 @@ jobs:
deploy:
runs-on: ubuntu-latest
env:
K3S_HOST: ${{ secrets.K3S_HOST }} # 你已配置的K3s服务器地址
# 从组织级Secrets读取不用在仓库重复配置
K3S_HOST: ${{ secrets.K3S_HOST }}
APP_NAME: ${{ gitea.repo_name }}
# 核心修改1跳过镜像推送避免依赖DockerHub密钥直接部署
# 若后续要推送镜像再配置REGISTRY和Docker密钥
steps:
- uses: gitea/actions/checkout@v4
- name: 拉取代码
uses: actions/checkout@v4
# 核心修改2删除Docker Buildx/登录/推送步骤(避免认证报错)
# 若后续需要构建推送镜像再恢复这部分并配置Docker密钥
# 核心修改3修复SSH部署步骤解决/k8s/deploy.yaml不存在
- name: SSH部署K3s
run: |
mkdir -p ~/.ssh
# 适配你已配置的密钥名K3S_SSH_KEY原K3S_PEM_KEY改为K3S_SSH_KEY
# 写入组织配置的SSH私钥
echo "${{ secrets.K3S_SSH_KEY }}" > k3s.pem
chmod 600 k3s.pem
# 关键上传仓库根目录的deploy.yaml到K3s临时目录解决路径不存在
scp -i k3s.pem -o StrictHostKeyChecking=no ./deploy.yaml root@${K3S_HOST}:/tmp/
# 执行kubectl命令指向临时文件+补充命名空间)
# 调试:验证私钥是否正确写入
echo "私钥文件权限:"
ls -l k3s.pem
echo "私钥头部仅前5行"
head -5 k3s.pem
# 测试连接会输出服务器主机名和kubectl版本
ssh -i k3s.pem -o StrictHostKeyChecking=no -o ConnectTimeout=10 root@${K3S_HOST} "hostname && kubectl version --client"
# 正式执行部署命令
ssh -i k3s.pem -o StrictHostKeyChecking=no root@${K3S_HOST} << CMD
kubectl apply -f /tmp/deploy.yaml
kubectl rollout restart deployment ${APP_NAME} -n default
# 可选:清理临时文件
rm -f /tmp/deploy.yaml
kubectl apply -f /data/k3s-data/deploy.yaml
kubectl rollout restart deployment ${APP_NAME}
CMD