171 lines
5.8 KiB
YAML
171 lines
5.8 KiB
YAML
name: Build Push and Deploy Image
|
||
|
||
on:
|
||
push:
|
||
#tag 触发
|
||
tags:
|
||
- 'v*'
|
||
# 分支触发
|
||
# branches:
|
||
# - main
|
||
workflow_dispatch: #手动构建h
|
||
|
||
#设置全局环境变量
|
||
env:
|
||
PATH: /opt/node/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
|
||
REGISTRY: ${{ secrets.DOCKER_REGISTRY }}
|
||
IMAGE_NAMESPACE: bamanker # todo 可以通过读取pom文件获取下面这些属性值
|
||
IMAGE_NAME: dailylove
|
||
APP_NAME: daily-love
|
||
|
||
# 构建 Job
|
||
jobs:
|
||
build:
|
||
runs-on: ubuntu-node22 # 如果host构建:linux_amd64
|
||
# container:
|
||
# image: swr.cn-north-4.myhuaweicloud.com/ddn-k8s/ghcr.io/catthehacker/ubuntu:act-latest
|
||
steps:
|
||
|
||
- name: Print system info 1
|
||
run: echo " The job was automatically triggered by a ${{ gitea.event_name }} event."
|
||
|
||
- name: Print system info 2
|
||
run: echo " This job is now running on a ${{ runner.os }} server hosted by Gitea!"
|
||
|
||
- name: Print system info 3
|
||
run: echo " The name of your branch is ${{ gitea.ref }} and your repository is ${{ gitea.repository }}."
|
||
|
||
- name: Print env
|
||
run: env && blkid
|
||
|
||
- name: Install dependencies
|
||
run: |
|
||
apt-get update &&
|
||
apt-get install -y gettext &&
|
||
apt-get install -y maven &&
|
||
apt-get install -y sudo &&
|
||
apt-get install -y iptables
|
||
|
||
- name: Set up Docker
|
||
uses: http://139.9.216.111:3000/bamanker/setup-docker-action@v4.6.0
|
||
with:
|
||
# 版本大于28会有兼容性问题
|
||
version: type=archive,channel=stable,version=v27.4.0
|
||
daemon-config: |
|
||
{
|
||
"registry-mirrors":["https://docker.1ms.run"],
|
||
"dns": ["8.8.8.8", "114.114.114.114"]
|
||
}
|
||
- name: Generate maven config
|
||
uses: http://139.9.216.111:3000/bamanker/maven-settings-action@v3.1.0
|
||
with:
|
||
mirrors: '[{"id": "alimaven", "name": "aliyun maven", "mirrorOf": "central", "url": "http://maven.aliyun.com/nexus/content/groups/public/"}]'
|
||
|
||
# - uses: http://localhost:3000/bamanker/setup-node@v6
|
||
# with:
|
||
# node-version: 24
|
||
# cache: 'npm'
|
||
# - run: node -v
|
||
# 下载仓库源码,依赖node环境,因此构建服务器本地需要下载安装node并设置环境变量
|
||
|
||
- name: Checkout repository code
|
||
#使用自定义仓库action
|
||
uses: http://139.9.216.111:3000/bamanker/checkout@v4
|
||
|
||
# 获取 TAG 并设置为环境变量
|
||
- name: Get version
|
||
id: get_version
|
||
# e.g. refs/tags/v1.0.0
|
||
run: |
|
||
echo "APP_TAG=${GITHUB_REF/refs\/tags\/v}" >> $GITHUB_ENV
|
||
|
||
# 检查 TAG 并传参
|
||
- name: Set envVar
|
||
id: set_envar
|
||
run: |
|
||
echo "The app version is $APP_TAG" && echo "tag=$APP_TAG" >> $GITHUB_OUTPUT &&
|
||
echo "now workspace: ${{ github.workspace }}"
|
||
|
||
# 为其他配置文件注入环境变量
|
||
- name: Inject envVar
|
||
run: |
|
||
envsubst < ./deployment-temp.yml > ./deployment.yml &&
|
||
cat ./deployment.yml
|
||
|
||
# 安装java环境
|
||
- name: Set up Java
|
||
uses: http://139.9.216.111:3000/bamanker/setup-graalvm@v1
|
||
with:
|
||
distribution: 'graalvm'
|
||
java-version: '25.0.1'
|
||
cache: 'maven'
|
||
# maven 构建
|
||
- name: Build with Maven
|
||
run: mvn clean native:compile -DskipTests -Pnative
|
||
|
||
# 登录镜像仓库,方便后续上传镜像
|
||
- name: Login to Docker Registry
|
||
uses: http://139.9.216.111:3000/bamanker/login-action@v3
|
||
with:
|
||
registry: ${{ env.REGISTRY }}
|
||
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
||
password: ${{ secrets.DOCKERHUB_PASSWORD }}
|
||
|
||
# # 获取时间戳
|
||
# - name: Get datetime
|
||
# id: datetime
|
||
# run: |
|
||
# echo "datetime=$(date '+%Y-%m-%d-%H-%M-%S')" >> $GITHUB_OUTPUT
|
||
|
||
# 构建并上传镜像
|
||
- name: Build and push Docker image
|
||
# uses: http://139.9.216.111:3000/bamanker/build-push-action@v4
|
||
# 获取上一步截取到的版本号,既 1.0.0
|
||
#只能这样接收
|
||
env:
|
||
TAG: ${{ steps.set_envar.outputs.tag }}
|
||
run: |
|
||
ls &&
|
||
docker build --file Dockerfile --tag ${{ env.REGISTRY }}/${{ env.IMAGE_NAMESPACE }}/${{ env.IMAGE_NAME }}:${{ env.TAG }} . &&
|
||
docker push ${{ env.REGISTRY }}/${{ env.IMAGE_NAMESPACE }}/${{ env.IMAGE_NAME }}:${{ env.TAG }}
|
||
|
||
# uses: http://139.9.216.111:3000/bamanker/docker-build-push@v5
|
||
# with:
|
||
# context: .
|
||
## platforms: linux/amd64
|
||
# file: Dockerfile
|
||
# push: true
|
||
# tags: ${{ env.REGISTRY }}/${{ env.IMAGE_NAMESPACE }}/${{ env.IMAGE_NAME }}:${{ env.TAG }}
|
||
|
||
#发布到 k8s
|
||
#安装 kubectl
|
||
- name: Setup kubectl
|
||
run: |
|
||
curl -LO "https://dl.k8s.io/release/v1.33.0/bin/linux/amd64/kubectl" &&
|
||
chmod +x kubectl &&
|
||
mv kubectl /usr/local/bin/
|
||
|
||
- name: Configure kubeconfig
|
||
# 假设您的 KUBE_CONFIG 秘密是 Base64 编码的 kubeconfig 文件内容
|
||
run: |
|
||
# 1. 创建 ~/.kube 目录
|
||
mkdir -p $HOME/.kube
|
||
|
||
# 2. 将 Base64 编码的 KUBE_CONFIG 秘密解码并写入默认配置文件
|
||
echo "${{ secrets.KUBE_CONFIG }}" | base64 -d > $HOME/.kube/config
|
||
|
||
# 3. 确保 kubectl 知道配置文件的位置 (可选, 但安全)
|
||
echo "KUBECONFIG=$HOME/.kube/config" >> $GITHUB_ENV
|
||
|
||
- name: Deploy with kubectl
|
||
run: |
|
||
kubectl apply -f ./deployment.yml
|
||
|
||
- name: k8s Check Pods Health
|
||
run: |
|
||
kubectl get pod -n default -l app=${{ env.APP_NAME }}
|
||
|
||
- name: k8s Update Deployment
|
||
run: |
|
||
kubectl rollout restart deployment ${{ env.APP_NAME }}
|