为 Deno 应用程序配置 CI/CD
先决条件
完成本指南的所有先前章节,从容器化 Deno 应用程序开始。您必须拥有一个 GitHub 帐户和一个 Docker 帐户才能完成此部分。
概述
在本节中,您将学习如何设置和使用 GitHub Actions 来构建和测试 Docker 镜像并将其推送到 Docker Hub。您将完成以下步骤
- 在 GitHub 上创建一个新仓库。
- 定义 GitHub Actions 工作流程。
- 运行工作流程。
第一步:创建仓库
创建一个 GitHub 仓库,配置 Docker Hub 凭据,并推送您的源代码。
打开仓库的“设置”,然后转到“Secrets and variables” > “Actions”。
创建一个新的仓库变量,命名为
DOCKER_USERNAME
,其值为您的 Docker ID。为 Docker Hub 创建一个新的个人访问令牌 (PAT)。您可以将此令牌命名为
docker-tutorial
。请确保访问权限包含 Read 和 Write。将 PAT 作为仓库密钥添加到您的 GitHub 仓库中,名称为
DOCKERHUB_TOKEN
。在您机器上的本地仓库中,运行以下命令将 origin 更改为您刚刚创建的仓库。请确保将
your-username
更改为您的 GitHub 用户名,并将your-repository
更改为您创建的仓库名称。$ git remote set-url origin https://github.com/your-username/your-repository.git
运行以下命令来暂存、提交并将您的本地仓库推送到 GitHub。
$ git add -A $ git commit -m "my commit" $ git push -u origin main
第二步:设置工作流程
设置 GitHub Actions 工作流程来构建镜像并将其推送到 Docker Hub。
转到您的 GitHub 仓库,然后选择“Actions”选项卡。
选择“set up a workflow yourself”(自行设置工作流程)。
这会带您进入一个页面,用于在您的仓库中创建新的 GitHub Actions 工作流程文件,默认路径为
.github/workflows/main.yml
。在编辑器窗口中,复制并粘贴以下 YAML 配置并提交更改。
name: ci on: push: branches: - main jobs: build: runs-on: ubuntu-latest steps: - name: Login to Docker Hub uses: docker/login-action@v3 with: username: ${{ vars.DOCKER_USERNAME }} password: ${{ secrets.DOCKERHUB_TOKEN }} - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 - name: Build and push uses: docker/build-push-action@v6 with: platforms: linux/amd64,linux/arm64 push: true tags: ${{ vars.DOCKER_USERNAME }}/${{ github.event.repository.name }}:latest
有关
docker/build-push-action
的 YAML 语法的更多信息,请参考GitHub Action README。
第三步:运行工作流程
保存工作流程文件并运行作业。
选择“Commit changes...”并推送到
main
分支。推送提交后,工作流程会自动启动。
转到“Actions”选项卡。它将显示工作流程。
选择工作流程会显示所有步骤的详细信息。
工作流程完成后,转到您在Docker Hub 上的仓库。
如果您在该列表中看到新仓库,则表示 GitHub Actions 已成功将镜像推送到 Docker Hub。
总结
在本节中,您学习了如何为 Deno 应用程序设置 GitHub Actions 工作流程。
相关信息
后续步骤
接下来,学习如何在部署到 Kubernetes 之前,在本地测试和调试您的工作负载。