惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

AI
AI
TaoSecurity Blog
TaoSecurity Blog
H
Heimdal Security Blog
Help Net Security
Help Net Security
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
Microsoft Azure Blog
Microsoft Azure Blog
www.infosecurity-magazine.com
www.infosecurity-magazine.com
Google DeepMind News
Google DeepMind News
爱范儿
爱范儿
The Cloudflare Blog
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
人人都是产品经理
人人都是产品经理
大猫的无限游戏
大猫的无限游戏
N
News | PayPal Newsroom
V2EX - 技术
V2EX - 技术
博客园 - 【当耐特】
D
Darknet – Hacking Tools, Hacker News & Cyber Security
S
Secure Thoughts
C
CERT Recently Published Vulnerability Notes
罗磊的独立博客
Exploit-DB.com RSS Feed
Exploit-DB.com RSS Feed
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
P
Privacy & Cybersecurity Law Blog
有赞技术团队
有赞技术团队
S
Schneier on Security
S
SegmentFault 最新的问题
Google Online Security Blog
Google Online Security Blog
H
Hacker News: Front Page
The Last Watchdog
The Last Watchdog
Schneier on Security
Schneier on Security
PCI Perspectives
PCI Perspectives
IT之家
IT之家
Project Zero
Project Zero
博客园 - 司徒正美
P
Privacy International News Feed
Recent Commits to openclaw:main
Recent Commits to openclaw:main
Jina AI
Jina AI
Security Latest
Security Latest
Hacker News - Newest:
Hacker News - Newest: "LLM"
腾讯CDC
C
CXSECURITY Database RSS Feed - CXSecurity.com
阮一峰的网络日志
阮一峰的网络日志
C
Check Point Blog
aimingoo的专栏
aimingoo的专栏
V
Vulnerabilities – Threatpost
W
WeLiveSecurity
NISL@THU
NISL@THU
Webroot Blog
Webroot Blog
N
Netflix TechBlog - Medium
L
Lohrmann on Cybersecurity

神代綺凛の随波逐流

VSCode 等宽字体之坑 - 神代綺凛の随波逐流 GitHub Actions 踩坑之——自己造! - 神代綺凛の随波逐流 Revolt 搭建指南 - 神代綺凛の随波逐流 [CloudCone] 洛杉矶/KVM/支持支付宝/$2换IP/1Gbps - 神代綺凛の随波逐流 让 Vue 使用指定配置文件进行构建 - 神代綺凛の随波逐流 借助 redis 实现访问控制 - 神代綺凛の随波逐流 在 Cloudflare Workers 上部署基于 Telegraf 框架的 Telegram Bot 一个由不透明响应引发的灾难 - 神代綺凛の随波逐流 油猴脚本入坑指南 - 神代綺凛の随波逐流
GitHub Actions 初体验及踩坑记录 - 神代綺凛の随波逐流
咕: 神代綺凛 · 2020-11-07 · via 神代綺凛の随波逐流

上周摸鱼摸到 GitHub Actions,听说今年 11 月就要正式向大众开放了,试了下蛮好玩的,但局限性和坑点也非常多

Head Pic: #アークナイツ frost - am1m的插画 - pixiv

GitHub Actions

官方介绍说,GitHub Actions 可以自动化和定制化项目的 Workflow,相当于官方钦定的 CI,目前仍处于 beta 阶段,想使用必须去手动点个按钮申请,听说 11 月会正式开放给全员

实际折腾了几天,给我的感受是,得益于 GitHub 这个平台,再加上你的创(xiao)造(nao)力(gua),Actions 能做到的事情确实很多,但有很多问题十分影响使用体验,后面会一一列出

使用前可以搜索一下已有的介绍文章、阅读官方文档来大致了解,真正使用的话我们主要阅读 Workflow syntaxContexts and expression syntax 文档就行了

你可以在 GitHub Marketplace 浏览寻找其他人开发的 actions,同时我推荐看看 sdras/awesome-actions 这个仓库,它收录了许多 GitHub Actions 相关的内容,并且对官方和他人开发的 actions 的功能做了分类与简略说明,方便你快速找到自己需要的 actions

用例与简单说明

与 Travis CI 相似,GitHub Actions 也使用 YAML 作为配置文件的格式,放在.github/workflows文件夹下

这是一个简单的示例,作用是当我更新 vue 项目文件时自动构建 dist 并发布到 GitHub Pages,然后推送到我的 Coding Pages 所在的远程仓库

下面我简单描述一下 GitHub Actions 中常用的语法,使你可以大概了解它能做什么

  • on规定什么时候触发 workflow
    • 可以由push,pull_request,release事件触发
    • 例如release这种事件可以定义具体类型
    • push,pull_request可以规定涉及具体分支branches、标签tags、路径path时触发
      • 路径可以用包含(path)或忽略(paths-ignore)两种模式,支持通配符,包含模式下可以用!声明例外目录
    • 可以由schedule定时触发,使用 cron 表达式
  • jobs是 workflow 的组成部分,每个 job 是在不同的容器内并行运行的,之间无法直接相互干涉
    • needs可以声明一个工作依赖另一个或多个 job,当这些 job 被完成后才会开始执行
    • runs-on系统环境,目前支持以下几个(以后估计会慢慢加)
      1. Windows Server 2019: windows-latest
      2. Ubuntu 18.04: ubuntu-latest or ubuntu-18.04
      3. Ubuntu 16.04: ubuntu-16.04
      4. macOS X Catalina 10.15: macos-latest
    • env定义环境变量,作用域为整个 job
    • if规定当满足某些条件时才执行这个 job
    • steps是 job 的组成部分,step 是顺序执行的
      1. env定义环境变量,作用域为当前 step,且你对环境变量的任何更改都不会带到其它 step 或者 job 中
      2. if规定当满足某些条件时才执行这个 step,并且可以使用状态检查函数,根据上一个 step 的状态决定是否运行
      3. uses声明使用其它 action 作为你的 step,也就是使用其他人写好的 action
      4. with为 uses 的 action 传入参数,具体看你使用的 action 的说明
      5. run运行命令,支持多行,具体看文档
      6. shell定义 run 所使用的 shell,具体看文档
      7. continue-on-error即使有错误也继续往下运行 step
      8. timeout-minutes规定该 step 的超时时间
    • timeout-minutes规定该 job 的超时时间
    • strategy定义一些矩阵供 job 使用,详细看文档
    • container容器具体信息,不规定时所有 step 将直接在runs-on规定的环境上运行,详细看文档
    • services声明使用哪些服务,例如nginxredis

Tips

  1. 涉密内容应使用 secrets(如何使用请阅读 Contexts and expression syntax),在项目 settings 中可以设置,此时 workflow 的日志中所有与 secrets 一致的内容都会用***替换;基于这一特性,若你想隐藏日志中会出现的某些词句,即使它们不需要被当做涉密变量在 workflow 中使用,你也可以将它们设置成 secrets
  2. 可以使用 actions/cache 来缓存一些可以重复利用的文件,例如 node_modules,可以节省时间减少网络开销等
  3. 当你觉得他人开发的 action 与你的需求相当贴合但就是差了那么一丢丢时,你可以 fork 并自行修改,然后直接用自己改过的 action

  1. 只有push,pull_request事件触发的 workflow 可以使用 actions/cache,详见 issue#64
  2. if内无法访问 secrets 上下文
  3. if内无法访问同级env
    • 例如job.<job_id>.step.if只能访问job.<job_id>.env中定义的环境变量,而不能访问job.<job_id>.step.env中定义的环境变量
  4. 综合 2 和 3,2 的变通解决方式是在上级env中声明一个环境变量来使用 secrets 的值,并且由于 3 的限制,你只能在 step 上这么操作
  5. 由于env的本质是字符串,因此在if中使用env时请注意数据类型
    • 例如在 job 中声明环境变量test: ${{ true }},在 step 的 if 中使用时,条件应当用env.test == 'true',而不是env.test == true
  6. workflow 中产生的事件无法直接触发另一个 workflow 的运行,详见 About workflow events
    • 例如 A 是定时运行,会往项目 push 代码,B 会在 push 事件发生时触发,则 A 的运行无法触发 B

版权声明:本文为原创文章,版权归 神代綺凜 所有。

本文链接:https://moe.best/gotagota/github-actions-experience.html

所有原创文章采用 知识共享署名-非商业性使用 4.0 国际许可协议 进行许可。
您可以自由的转载和修改,但请务必注明文章来源并且不可用于商业目的。

搬瓦工VPS优惠套餐,建站稳如狗,支持支付宝,循环出账94折优惠码BWH3HYATVBJW
年付$47CN2线路,1核/1G内存/20G硬盘/1T@1Gbps【点击购买
季付$47CN2 GIA线路,1核/1G内存/20G硬盘/1T@2.5Gbps【点击购买