Gitea Action 简单配置(CI/CD)

线上pipeline,(我使用是本地仓库的,你们使用切换成官网的即可)

yaml 复制代码
# 工作流的名称

name: Build and Push Docker Image deployment-k8s

# 触发条件,只在 master 或 main 分支发送推送时触发
on:
  push:
    branches:
      - main

# 作业,工作流运行由一个或多个 jobs 组成,默认情况下并行运行
jobs:
  build-and-push-image:
    # 定义要运行作业的计算机类型
    runs-on: ubuntu-latest
    steps:
    # 检出代码
    - name: Checkout Code
      #uses: actions/checkout@v4
      uses: http://192.168.0.20:3000/admins/checkout@main

    # 设置 Docker BuildX
    - name: Set up Docker Buildx
      id: buildx
      #uses: docker/setup-buildx-action@v2.6.0
      uses: http://192.168.0.20:3000/admins/setup-buildx-action@v2.6.0

    # 登录 Registry       
    - name: Login to DockerHub
      #uses: docker/login-action@v2
      uses: http://192.168.0.20:3000/admins/login-action@v3
      with:
        registry: ${{ secrets.REGISTRY }}
        username: ${{ secrets.DOCKER_USERNAME }}
        password: ${{ secrets.DOCKER_PASSWORD }}
   
   
    # 构建并推送 Docker 镜像
    - name: Build Docker Image 
      id: docker_build
      uses: http://192.168.0.20:3000/admins/build-push-action@v4
      #uses: docker/build-push-action@v4
      with:
        push: true
        file: ./Dockerfile-uat
        tags: ${{ secrets.REGISTRY_PATH }}/www:${{ github.sha }}

    # 部署k8s
    - name: deploy to cluster
      #uses: actions-hub/kubectl@master
      uses: http://192.168.0.20:3000/admins/kubectl@main
      env:
        KUBE_CONFIG: ${{ secrets.KUBE_CONFIG_DATA_160 }}
      with:
        args: set image deployment/www-web www-web=${{ secrets.REGISTRY_PATH }}/www:${{ github.sha }}  -n test

    - name: verify deployment
      uses: http://192.168.0.20:3000/admins/kubectl@main
      env:
        KUBE_CONFIG: ${{ secrets.KUBE_CONFIG_DATA_160 }}
      with:
        args: rollout status deployment/www-web  -n test
流水线变量 --- 设置>>>> Runner >>> 密钥(输入你的变量)

注意原生使用k8s,然后在加入变量中

js 复制代码
cat $HOME/.kube/config | base64

如果你是AWS EKS如下简单配置使用专门EKS镜像:

js 复制代码
    - name: Deploy Application
      uses: statsig-io/kubectl-via-eksctl@main
      env:
        aws_access_key_id: ${{ secrets.AWS_ACCESS_KEY_ID }}
        aws_secret_access_key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
        region: ap-northeast-1
        cluster: ${{ secrets.CLUSTER_NAME }}
      with:
        args: get pods -n prometheus
        #args: set image deployment/my-app container=${{ github.repository}}:${{ github.sha }}
Gitea Action工具链更丰富以下是他的市场和工具链,大家可以自己选择自己喜欢的工具
js 复制代码
#镜像包
https://github.com/actions/runner-images?tab=readme-ov-file#available-images

#入门文档
https://docs.github.com/zh/actions/writing-workflows/quickstart

#市场
https://github.com/marketplace?type=actions
最后还可以加入一个webhook,目前只找到一个飞书的
yaml 复制代码
    - name: Send Text Message
      #uses: foxundermoon/feishu-action@v2
      uses: http://192.168.0.20:3000/admins/feishu-action@v2
      with:
        url: ${{ secrets.FEISHU_BOT_WEBHOOK_URL }}
        msg_type: text
        content: |
          text: |
           发布者/项目名: ${{ github.repository }}
           项目状态: ${{ job.status }}   
相关推荐
裁二尺秋风2 天前
CI/CD — Pipeline的使用以及Blue Ocean多分支流水线的使用方法
ci/cd·gitlab·jenkins
真实的菜2 天前
Jenkins 插件深度应用:让你的CI/CD流水线如虎添翼 [特殊字符]
servlet·ci/cd·jenkins
元媛媛3 天前
什么是持续集成/持续交付(CI/CD)?
ci/cd
学习溢出3 天前
【网络安全】持续监控CI/CD:自动发现威胁与IoCs,软件供应链安全
运维·安全·web安全·网络安全·ci/cd
问~16 天前
gitea本地部署代码托管后仓库的新建与使用(配置好ssh密钥后仍然无法正常克隆仓库是什么原因)
运维·ssh·gitea
‌Freiheit16 天前
[持续集成]
ci/cd
Fireworkitte16 天前
在 CI/CD 流程中使用 Jenkins 与 Docker 集成
ci/cd·docker·jenkins
神志不清.16 天前
Jenkins通过Pipeline流水线方式编译Java项目
java·运维·ci/cd·jenkins·devops
tswddd17 天前
项目:Gitlab HSD CI/CD总结
ci/cd·kubernetes·gitlab
Haoea!17 天前
持续集成 CI/CD-Jenkins持续集成GitLab项目打包docker镜像推送k8s集群并部署至rancher
ci/cd·gitlab·jenkins·rancher