经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 软件/图像 » Git » 查看文章
带你学习通过GitHub Actions如何快速构建和部署你自己的项目,打造一条属于自己的流水线
来源:cnblogs  作者:初夏的阳光丶  时间:2024/7/29 9:31:09  对本文有异议

本文主要讲解通过github的actions来对我们项目进行ci/cd

  1. System.out.println("原文地址:https://www.cnblogs.com/ancold/p/18327097");

一、actions简介

GitHub Actions 是一种持续集成和持续交付 (CI/CD) 平台,可用于自动执行生成、测试和部署管道。 您可以创建工作流程来构建和测试存储库的每个拉取请求,或将合并的拉取请求部署到生产环境。

GitHub Actions 不仅仅是 DevOps,还允许您在存储库中发生其他事件时运行工作流程。 例如,您可以运行工作流程,以便在有人在您的存储库中创建新问题时自动添加相应的标签。

GitHub 提供 Linux、Windows 和 macOS 虚拟机来运行工作流程,或者您可以在自己的数据中心或云基础架构中托管自己的自托管运行器。

下面是一个简单的实例和简介

  1. # 可选 - 工作流的名称,将显示在 GitHub 仓库的 "Actions" 标签中。如果省略此字段,将使用工作流文件的名称。
  2. name: learn-github-actions
  3. # 可选 - 从工作流生成的工作流运行的名称,将显示在您的仓库的 "Actions" 标签的工作流运行列表中。此示例使用带有 `github` 上下文的表达式来显示触发工作流运行的用户的用户名。有关更多信息,请参阅 "[AUTOTITLE](/actions/using-workflows/workflow-syntax-for-github-actions#run-name)"。
  4. run-name: ${{ github.actor }} is learning GitHub Actions
  5. # 指定触发此工作流的触发器。此示例使用 `push` 事件,因此每次有人推送更改到仓库或合并拉取请求时都会触发工作流运行。这是由推送到每个分支触发的;有关仅在推送到特定分支、路径或标签时运行的语法示例,请参阅 "[AUTOTITLE](/actions/reference/workflow-syntax-for-github-actions#onpushpull_requestpull_request_targetpathspaths-ignore)"。
  6. on: [push]
  7. # 将所有在 `learn-github-actions` 工作流中运行的任务分组在一起。
  8. jobs:
  9. # 定义一个名为 `check-bats-version` 的任务。子键将定义该任务的属性。
  10. check-bats-version:
  11. # 配置该任务在最新版本的 Ubuntu Linux 运行器上运行。这意味着该任务将在 GitHub 托管的新虚拟机上执行。有关使用其他运行器的语法示例,请参阅 "[AUTOTITLE](/actions/reference/workflow-syntax-for-github-actions#jobsjob_idruns-on)"
  12. runs-on: ubuntu-latest
  13. # 将在 `check-bats-version` 任务中运行的所有步骤分组在一起。嵌套在此部分下的每个项都是一个独立的操作或 shell 脚本。
  14. steps:
  15. # `uses` 关键字指定此步骤将运行 `actions/checkout` 操作的 `v4` 版本。这是一个将您的仓库检出到运行器上的操作,允许您针对您的代码运行脚本或其他操作(例如构建和测试工具)。当您的工作流将使用仓库的代码时,您应该使用检出操作。
  16. - uses: actions/checkout@v4
  17. # 此步骤使用 `actions/setup-node@v4` 操作来安装指定版本的 Node.js。(此示例使用 20 版本。)这会将 `node` 和 `npm` 命令放入您的 `PATH` 中。
  18. - uses: actions/setup-node@v4
  19. with:
  20. node-version: '20'
  21. # `run` 关键字告诉任务在运行器上执行命令。在这种情况下,您正在使用 `npm` 来安装 `bats` 软件测试包。
  22. - run: npm install -g bats
  23. # 最后,您将运行带有输出软件版本参数的 `bats` 命令。
  24. - run: bats -v

二、前置动作

  1. 准备一台服务器
  2. 申请阿里云镜像仓库服务,申请地址:https://cr.console.aliyun.com/
  3. 能够正常访问github
  4. 新建一个Java SpringBoot项目推送到github代码仓库中
  5. 代码仓库中配置对应的secrets and variables,下一步会教大家配置

三、配置secrets and variables

具体配置位置如下图
我这边使用的实例用了如下的一些secrets

  1. DOCKER_LOGIN_URL 阿里云镜像仓库地址
  2. DOCKER_PASSWORD 阿里云镜像仓库密码
  3. DOCKER_USERNAME 阿里云镜像仓库账号
  4. SERVER_IP 服务器Ip
  5. SERVER_USER_NAME 服务器名称
  6. SSH_PASSWORD 服务器密码

四、创建workflows

点击Actions--New workflows 它会在项目更目录默认创建一个文件夹.github\workflows

选择Docker image

五、编写Dockerfile

因为主要是用来做一个实例,所以我这边编写的Dockerfile就比较简单,如果大家有自己的需求,劳请自行修改
Dockerfile存放位置为:.github\workflows 同docker-image.yml同级

  1. FROM openjdk:17
  2. WORKDIR /app
  3. COPY spring-boot-build-3.3.2.jar /app/spring-boot-build-3.3.2.jar
  4. EXPOSE 8080
  5. ENTRYPOINT ["java","-jar","/app/spring-boot-build-3.3.2.jar"]

六、编写发布流水线配置

  1. name: Docker-Image-CI
  2. on:
  3. push:
  4. branches: [ "main" ]
  5. pull_request:
  6. branches: [ "main" ]
  7. jobs:
  8. build:
  9. runs-on: ubuntu-latest
  10. steps:
  11. - name: Check out the code
  12. uses: actions/checkout@v2
  13. - name: Set up QEMU
  14. uses: docker/setup-qemu-action@v1
  15. - name: Set up Docker Buildx
  16. uses: docker/setup-buildx-action@v1
  17. - name: Set up JDK 17
  18. uses: actions/setup-java@v3
  19. with:
  20. java-version: '17'
  21. distribution: 'temurin'
  22. - name: Build with Maven
  23. run: mvn clean package
  24. - name: Move JAR to .github/workflows
  25. run: |
  26. mkdir -p .github/workflows
  27. mv target/*.jar .github/workflows/
  28. - name: Log in to Aliyun Docker Registry
  29. env:
  30. ALIYUN_DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }}
  31. ALIYUN_DOCKER_PASSWORD: ${{ secrets.DOCKER_PASSWORD }}
  32. ALIYUN_DOCKER_URL: ${{ secrets.DOCKER_LOGIN_URL }}
  33. run: |
  34. echo "${ALIYUN_DOCKER_PASSWORD}" | docker login "${ALIYUN_DOCKER_URL}" --username "${ALIYUN_DOCKER_USERNAME}" --password-stdin
  35. - name: Remove old Docker images
  36. run: |
  37. docker images --format '{{.Repository}}:{{.Tag}}' | grep 'registry.cn-hangzhou.aliyuncs.com/benxiong_default/public' | xargs -I {} docker rmi -f {}
  38. - name: Build Docker image
  39. run: docker build -f .github/workflows/Dockerfile -t springbuild .github/workflows/
  40. - name: Tag Docker image
  41. run: docker tag springbuild 阿里云镜像仓库tag:latest
  42. - name: Push Docker image to Aliyun registry
  43. run: docker push 阿里云镜像仓库地址:latest
  44. - name: Set up SSH using username and password
  45. env:
  46. SSH_PASSWORD: ${{ secrets.SSH_PASSWORD }}
  47. SSH_USER: ${{ secrets.SERVER_USER_NAME }}
  48. SERVER_IP: ${{ secrets.SERVER_IP }}
  49. run: |
  50. sudo apt-get update
  51. sudo apt-get install -y sshpass
  52. sshpass -p "${SSH_PASSWORD}" ssh -o StrictHostKeyChecking=no ${SSH_USER}@${SERVER_IP} << 'EOF'
  53. # Stop and remove old container
  54. sudo docker ps -q -f "name=容器名称" | xargs -r sudo docker stop
  55. sudo docker ps -aq -f "name=容器名称" | xargs -r sudo docker rm
  56. # Remove old Docker images
  57. sudo docker image prune -a -f
  58. # Remove the specific Docker image
  59. sudo docker rmi -f 镜像名称
  60. # Pull the new Docker image
  61. sudo docker pull 镜像名称
  62. # Run the new container
  63. sudo docker run -d --name 容器名称--restart unless-stopped -p 9000:9000 镜像名称:latest
  64. EOF

七、结语

通过以上的一套操作下来,我们就可以在提交代码main分支后,通过workflows就能自动的去帮助我们执行构建和部署的操作了,非常方便我们开发者,也不需要我们再去部署jenkins,也不需要学习jenkins的pipeline语法了,同时也不得不说一句,github nb!!!

gthub actions官方地址:https://docs.github.com/zh/actions/learn-github-actions/understanding-github-actions

如有哪里讲得不是很明白或是有错误,欢迎指正
如您喜欢的话不妨点个赞收藏一下吧??

原文链接:https://www.cnblogs.com/ancold/p/18327097

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号