GitHub Actions 和 CI/CD 管道
来源:dev.to
时间:2024-10-24 17:31:09 252浏览 收藏
知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个文章开发实战,手把手教大家学习《GitHub Actions 和 CI/CD 管道》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!

当然!以下是与 github actions 和 ci/cd 管道相关的关键概念和实践的全面摘要,以及我们讨论的示例:
github actions 和 ci/cd 管道的关键概念
- 持续集成(ci):
ci 涉及自动构建和测试代码更改,以确保它们与现有代码库良好集成。
github actions 通过在推送或 pull_request 等事件上运行工作流程来启用 ci。
- 持续部署(cd):
cd 是 ci 的扩展,在成功构建和测试后自动将代码部署到生产环境。
可以在 github actions 中配置 cd,以便在所有测试通过后将应用程序部署到各种平台。
- 工作流程:
工作流程是在 yaml 文件中定义的自动化流程,位于存储库的 .github/workflows/ 目录中。
工作流程可以由各种事件(例如推送、拉取请求)触发,并且可以包含多个作业和步骤。
- 工作:
作业是在同一运行器(环境)上执行的一组步骤。作业可以并行或顺序运行,具体取决于它们之间定义的依赖关系。
- 步骤:
步骤是作为作业的一部分执行的单独任务。每个步骤都可以运行命令、使用操作或运行脚本。
- 行动:
操作是可重用的代码片段,可以组合起来创建工作流程。您可以使用官方操作、社区操作或创建自定义操作。
- 跑步者:
运行器是一个在触发时运行您的工作流程的服务器。 github 提供托管运行器(linux、windows、macos),您也可以自行托管运行器。
示例场景
- 使用 ci/cd 的 node.js 应用程序
存储库结构:
你的仓库/
├── .github/
│ └── 工作流程/
│ ├── node-check.yml
│ └── linter.yml
├── src/
│ └── check-node.js
├── package.json
└── readme.md
ci/cd 工作流程示例 (node-check.yml):
名称:node.js 检查
于:
推:
分支机构:
- 主要
pull_request:
分支机构:
- 主要
工作:
检查节点:
运行:ubuntu-latest
steps:
- name: checkout code
uses: actions/checkout@v2
- name: set up node.js
uses: actions/setup-node@v2
with:
node-version: '14'
- name: install dependencies
run: npm install
- name: run node.js script
run: npm run check
linter 工作流程示例 (linter.yml):
名称:lint 代码库
于:
推:
分支机构:
- 主要
pull_request:
分支机构:
- 主要
工作:
短绒:
运行:ubuntu-latest
步骤:
- 名称:结帐代码
使用:actions/checkout@v2
- name: Lint Code
uses: github/super-linter@v5
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
DEFAULT_BRANCH: main
- 设置 github super linter
超级 linter 配置 (linters.yml):
短绒:
eslint:
启用:true
markdownlint:
启用:true
jsonlint:
启用:true
要点
自动化:github actions 可自动化您的软件开发工作流程,实现 ci/cd 实践,从而提高生产力和代码质量。
版本控制集成:github actions 与 github 存储库无缝集成,允许您根据存储库事件触发工作流程。
可配置性:工作流程可通过 yaml 文件进行高度可配置,从而可以轻松定义条件、环境和任务。
社区和可重用性:github actions 生态系统提供了社区创建的各种操作和工作流程,促进了重用和协作。
可见性和反馈:您可以在 github actions 选项卡中从工作流程中获取实时反馈,帮助您在开发过程中及早发现问题。
结论
使用 github actions 进行 ci/cd 管道可以简化测试和部署应用程序的过程,使开发人员能够专注于编写代码,而不是管理构建和部署过程。凭借可配置的工作流程、集成的 linter 和强大的自动化功能,github actions 是现代软件开发实践中的宝贵工具。
到这里,我们也就讲完了《GitHub Actions 和 CI/CD 管道》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
325 收藏
-
405 收藏
-
413 收藏
-
293 收藏
-
356 收藏
-
119 收藏
-
182 收藏
-
288 收藏
-
120 收藏
-
392 收藏
-
321 收藏
-
2. CSS 样式使用 ::after 伪元素来在图片上叠加文字:
.im" class="aBlack">CSS图片上叠加文字的实现方法,主要通过使用伪元素(如 ::after)来在图片上方添加内容。以下是详细步骤和示例代码:1. HTML 结构假设你有一个包含图片的容器,结构如下:2. CSS 样式使用 ::after 伪元素来在图片上叠加文字: .im