GitHub Actions 是一个非常强大的工具,可以用来实现各种自动化任务,包括自动编译和发布 release。以下是一个基本的工作流程,展示如何使用 GitHub Actions 实现这一目标:

  1. 创建 GitHub Actions 工作流文件:在你的 GitHub 仓库中,创建一个 .github/workflows 目录,并在该目录中创建一个新的工作流文件,例如 release.yml

  2. 定义工作流:在 release.yml 文件中,定义你的工作流步骤。以下是一个示例工作流,它演示了如何在每次推送到 main 分支时进行编译并创建一个新的 release。

name: Build and Release

on:
push:
branches:
- main
workflow_dispatch: jobs:
build:
runs-on: ubuntu-latest steps:
- name: Checkout repository
uses: actions/checkout@v4 - name: Set up Node.js
uses: actions/setup-node@v2
with:
node-version: "14" - name: Install dependencies
run: npm install - name: Build project
run: npm run build - name: Archive production artifacts
uses: actions/upload-artifact@v4
with:
name: build-artifacts
path: build/ release:
needs: build
runs-on: ubuntu-latest steps:
- name: Download build artifacts
uses: actions/download-artifact@v4
with:
name: build-artifacts - name: Create GitHub Release
id: create_release
uses: actions/create-release@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag_name: v1.0.0
release_name: Release v1.0.0
body: |
Release notes for v1.0.0
draft: false
prerelease: false - name: Upload Release Asset
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: build/
asset_name: build-artifacts.zip
asset_content_type: application/zip

解释

  1. 工作流名称和触发器

    • name: Build and Release:定义工作流的名称。
    • on 条件定义了工作流何时被触发,这里是每当推送到 main 分支时触发。
  2. 构建作业

    • runs-on: ubuntu-latest:指定工作流程运行的环境。
    • actions/checkout@v4:将代码仓库检出到 runner。
    • actions/setup-node@v2:设置 Node.js 环境。
    • npm install:安装项目依赖。
    • npm run build:构建项目。
    • actions/upload-artifact@v4:将构建的工件上传,以便在后续步骤中使用。
    • actions/upload-artifact 的实现代码可以在 https://github.com/actions/upload-artifact 找到。
  3. 发布作业

    • needs: build:指定此作业依赖于名为 build 的作业。
    • actions/download-artifact@v2:下载构建工件。
    • actions/create-release@v1:在 GitHub 上创建一个新 release。GITHUB_TOKEN 用于进行身份验证。
    • actions/upload-release-asset@v1:将构建工件作为 release 资源上传。

注意事项

  • GITHUB_TOKEN:GitHub 提供的内置秘密,用于在 Actions 中进行身份验证。
  • 自定义步骤:根据你的项目和需求,你可能需要调整或添加步骤。例如,编译步骤可能会有所不同,具体取决于你使用的编程语言和构建工具。
  • 版本号:在实际使用中,你可能希望自动生成版本号而不是硬编码版本号。

参见:GitHub Actions 文档

更多示例代码

# .github/workflows/github-actions-demo.yaml
# 将代码打包为 tar.gz 并发布 name: Auto Release # 工作流名 run-name: Auto Release # 运行时的工作流名 on: [push] jobs:
build: # job 名可以自定义
runs-on: ubuntu-latest # 也可以是容器
steps:
- name: Checkout repository
uses: actions/checkout@v4 - name: Package VM
run: tar -zcvf VM.tar.gz VM - name: Package VPS
run: tar -zcvf VPS.tar.gz VPS - name: Upload Artifact VM.tar.gz
uses: actions/upload-artifact@v4
with:
name: VM.tar.gz
path: VM.tar.gz - name: Upload Artifact VPS.tar.gz
uses: actions/upload-artifact@v4
with:
name: VPS.tar.gz
path: VPS.tar.gz - name: Extract branch name
shell: bash
run: echo "##[set-output name=branch;]$(echo ${GITHUB_REF#refs/heads/})"
id: extract_branch - name: Create Release
id: create_release
uses: actions/create-release@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag_name: ${{ steps.extract_branch.outputs.branch }}-${{ github.run_number }}
release_name: Release for ${{ steps.extract_branch.outputs.branch }} at ${{ github.sha }}
draft: false
prerelease: false - name: Upload Release Asset 1
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ./VM.tar.gz
asset_name: VM.tar.gz
asset_content_type: application/gzip - name: Upload Release Asset 2
uses: actions/upload-release-asset@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
upload_url: ${{ steps.create_release.outputs.upload_url }}
asset_path: ./VPS.tar.gz
asset_name: VPS.tar.gz
asset_content_type: application/gzip # 一些可用变量
# runner.os: 运行 Action 的系统名
# job.status: job 的状态
# github.actor: 运行的 Action
# github.event_name: 触发 Action 的事件名
# github.ref: 当前分支名
# github.repository: 存储库名
# github.workspace: 存储库工作区

通过 GitHub Actions 实现代码的自动编译和发布的更多相关文章

  1. Ant自动编译打包&发布 android项目

    Eclipse用起来虽然方便,但是编译打包android项目还是比较慢,尤其将应用打包发布到各个渠道时,用Eclipse手动打包各种渠道包就有点不切实际了,这时候我们用到Ant帮我们自动编译打包了. ...

  2. 项目管理实践【五】自动编译和发布网站【Using Visual Studio with Source Control System to build and publish website automatically】

    在上一篇教程项目管理实践[三]每日构建[Daily Build Using CruiseControl.NET and MSBuild] 中,我们讲解了如何使用CCNET+MSBuild来自动编译项目 ...

  3. Andorid进阶7—— Ant自动编译打包&发布 android项目

    http://www.cnblogs.com/tt_mc/p/3891546.html Eclipse用起来虽然方便,但是编译打包android项目还是比较慢,尤其将应用打包发布到各个渠道时,用Ecl ...

  4. Intellij IDEA 修改代码后自动编译更新

    Intellij IDEA 一些不为人知的技巧 问题描述: Intellij IDEA 调试修改时,改动页面和 java 文件后,无法立刻看到变化,需要手动重启服务. 问题原因: 在 IDEA tom ...

  5. webpack学习_webpack-dev-server自动编译代码

    之前每次修改完之后都要执行npm run build来编译,下面有三种方式可以实现代码变化后自动编译代码,下面只重点说webpack-dev-server,其他的请看webpack开发文档 1.web ...

  6. rebar3自动编译

    功能:修改完代码可以自动编译加载到VM中 必须安装的软件: Linux: inotify  链接https://github.com/rvoicilas/inotify-tools/wiki 配置: ...

  7. 如何搭建自己的CICD流水线,实现自动编译部署功能?

    之前使用过GitLab的CICD流水线,有多种环境,点击即可编译部署,十分的方便. 如何在个人项目中搭建自己的CICD流水线,实现push代码后自动编译并部署呢?这里使用到阿里云 云效DevOps,阿 ...

  8. maven 使用之自动编译热部署设置

    参见创建webapp项目 eclipse Maven 使用记录 ------ 建立 webapp项目 在maven中为实现热部署设置,部署至webapp,即webroot 设置classes输出目的地 ...

  9. 为Github仓库添加Github Actions实现持续集成: Android apk自动编译发布以及github pages同步推送coding.net

    内容转载自我的博客 目录 说明 1. 编写Android项目的CI配置文件 2. 编写Jekyll项目的CI配置文件 2.1 配置coding.net 2.2 配置github 2.3 自动部署到co ...

  10. 使用GitHub Actions自动编译部署hexo博客

    前言 使用hexo博客也挺久的,最开始是本地hexo clean && hexo g,最后hexo d推送到服务器.后来是本地hexo clean && hexo g, ...

随机推荐

  1. bs4解析-湖南农场品价格行情

    import requests from bs4 import BeautifulSoup import csv url = 'https://price.21food.cn/market/174-p ...

  2. (sql语句试题练习及 参考答案解题思路+个人解题思路)

    SQL字段说明及数据 ======================================================================= 一.部门表字段描述:dp_no 部 ...

  3. HTTP常见的状态码?

    100 Continue 继续,一般在发送post请求时,已发送了http header之后服务端将返回此信息,表示确认,之后发送具体参数信息 200 OK 正常返回信息 201 Created 请求 ...

  4. SpringBoot 文件打包zip,浏览器下载出去

    本地文件打包 /** * 下载压缩包 * * @param response */ @ResponseBody @GetMapping("/downloadZip") public ...

  5. influxdb得导出与导入

    转载请注明出处: 1.备份元数据 基本语法: influxd backup <path-to-backup> 备份元数据,没有任何其他参数,备份将只转移当前状态的系统元数据到path-to ...

  6. JavaScript系列:JS实现复制粘贴文字以及图片

    目录 一. 基于 Clipboard API 复制文字(推荐) 基本概念 主要方法 使用限制 实际应用示例 二.基于 document.execCommand('copy') 缺陷 实际应用示例 说明 ...

  7. linux系统是未来_大小写敏感_case_sensitive_编程原生态

    修改 py 文件 回忆上次内容 上次尝试了 两个vim 同时打开 同一py文件 vim出现了Error 有各种选择     错误拼写 pront 导致 运行时 出现了NameError         ...

  8. 2023HACSP-J补测

    都快忘了自己还打过这个比赛了,所以来补一下. 完整题目在这里查看. Day0 来到郑州,寻找考场.幸好提前来了,因为考场大门就 5m 宽(HA用不用这么穷啊喂,来JZYZ不好么),开车转了 20min ...

  9. Packer构建openStack镜像

    目录 使用Packer自动化构建镜像 使用Packer自动化构建镜像 openstack插件安装:OpenStack | Integrations | Packer | HashiCorp Devel ...

  10. Springboot + Vue ElementUI 实现MySQL可视化

    一.功能展示: 效果如图: DB连接配置维护:   Schema功能:集成Screw生成文档,导出库的表结构,导出表结构和数据 表对象操作:翻页查询,查看创建SQL,生成代码 可以单个代码文件下载,也 ...