GitHub Actions 入门实践

前言

GitHub Actions 是 GitHub 推出的功能,可以为我们的项目构建自动化工作流。例如代码检查,自动化打包,测试,发布版本等等。入口在项目 Pull Requests 旁边。

本篇文章主要是趟一遍其中的小坑,让大家在第一次使用的时候能比较顺利的跑通。其中主要用到了 GitHub,Docker,SpringBoot,Nginx 等技术。对这些技术还不是很了解的伙伴,可以先自行查阅一下资料哈。😊

实践步骤

创建 SpringBoot 工程

使用 IDEA 创建一个 SpringBoot 工程,SpringBoot 从 2.3.0.M1 版本开始用 Gradle 构建。所以我们这里也选 Gradle 作为构建工具 🔧。

We made a fairly significant change to Spring Boot in 2.3.0.M1. It was the first release of the project to be built with Gradle rather than Maven.

🔎 详情可参考 Migrating Spring Boot’s Build to Gradle

在 SpringBoot 工程中,我们编写一个简单的控制器用于测试,代码十分简单,这里也给出示例。

@RestController
public class DemoController {
    @GetMapping("/")
    public String sayHello() {
        return "Hello GitHub Actions!";
    }
}

编写 Dockerfile 文件

在 SpringBoot 工程中创建 Dockerfile 文件,用于镜像打包 📦。

# FROM 指定基础镜像
FROM openjdk:8-jdk-alpine
# ARG 构建参数
ARG JAR_FILE=build/libs/*.jar
# COPY 复制文件
COPY ${JAR_FILE} app.jar
# 暴露端口
EXPOSE 8080
# CMD 容器启动命令
CMD java -jar /app.jar

还不了解 Dockerfile 的小伙伴可前往 使用 Dockerfile 定制镜像 了解一下基础知识。

创建 Docker Registry

这一步小伙伴们可以自由选择阿里云或者腾讯云等云服务商开通相应服务,之后我们打包好的镜像要上传到我们自己私有的 Docker Registry 中。这一步很重要大家一定要开通好再进行下面的步骤哈。

开通好服务之后,可稍微阅读一下服务商的文档,对该服务有个大概的基本认识即可。

本篇文章中使用的云服务商是阿里云,大家可点击这里进行开通与配置。

上传代码

将我们的 SpringBoot 工程上传到 GitHub Repository 中,关于怎么创建 GitHub Repository,相信各位小伙伴都产生肌肉记忆了吧 💪!

git init
git add .
git commit -m "first commit"
git remote add origin {{ your origin url }}
git push -u origin master

进入 SpringBoot 工程目录,输入上面这几条命令,就可以轻松将代码上传至你的 GitHub Repository。

配置 GitHub Actions

我们点击 Actions 选项卡,选择 Java with Gradle 模版作为基础模版进行配置。

# GitHub Actions 的名称
name: GitHub Actions SpringBoot Demo

# 当 master 分支发生 push 或者 pull request 事件时触发 action
on:
  push:
    branches: [ master ]
  pull_request:
    branches: [ master ]

# 指定 jobs
jobs:
  # build job
  build:

    # 指定运行在 ubuntu 上
    runs-on: ubuntu-latest
    steps:

    # 把仓库代码拉到 ubuntu 镜像上
    - uses: actions/checkout@v2

    # 指定 java 版本
    - name: Set up JDK 1.8
      uses: actions/setup-java@v1
      with:
          java-version: 1.8

    # 给 gradle 赋予可运行权限
    - name: Grant execute permission for gradlew
      run: chmod +x gradlew

    # 通过 gradle 打包我们的项目
    - name: Build with gradle
      run: ./gradlew build

    # 通过 Dockerfile 构建镜像
    - name: Build docker image
      run: docker build . -t {{ image_name:image_version }}
    
    # 登陆到我们自己的 docker registry
    - name: Login to aliyun docker image registry
      run: echo "${{ secrets.REGISTRY_PASSWORD }}" |  docker login --username=xxxxxx registry.cn-shenzhen.aliyuncs.com --password-stdin

    # 上传 docker 镜像
    - name: Push image to aliyun docker image registry
      run: docker push {{ image_name:image_version }}

配置文件中的 ${{ secrets.XXX }} 变量,是 GitHub 为了保护我们的密钥所提供的功能。可以在仓库的 Settings 下的 Secrets 中定义变量,然后按照 ${{ secrets.XXX }} 的格式,就可以拿到变量值。

到这儿,我们就完成了 GitHub Actions 的配置文件编写。小伙伴们需要注意一下 yaml 文件的格式,不要出现格式错误。

触发 GitHub Actions

完成配置文件的编写之后,我们点击 start commit 进行提交,提交成功后会自动触发 Actions 功能进行构建。

点击 Actions 选项卡,找到被触发的 Actions,等待片刻即可看见构建结果。如果构建中途出现了错误,也可直接在这里看见原因并前往配置文件排查。

构建完成之后,我们可以进入相应的云服务商后台查看一下我们上传的 Docker 镜像,再次确认是否构建成功!

部署到服务器

小伙伴们确认一下自己的服务器是否已经安装 Nginx,Docker。如果还没有安装,可以先查阅相关资料进行安装。安装成功之后,再进行下列步骤。

这里我们要准备一份简单的服务器部署 bash 脚本,完成对旧容器的关闭删除,对新镜像的拉取并且构建新容器操作。这里有一份简单的例子可以参考。

# 拉取新镜像
docker pull {{ your image_name:image_version }}
# 停止旧容器
docker stop {{ your container name }}
# 删除停止的容器
docker container prune -f

# 构建新容器
docker run \
-p 8080:8080 \
-v /data:/data \
--name {{ your container name }} \
-d {{ your image_name:image_version }}

我们需要对上面编写好的 GitHub Actions 配置文件增加一些内容,主要作用是推送完 Docker 镜像之后,触发远程服务器拉取镜像重新构建,并用新的镜像启动容器。完整的 GitHub Actions 配置文件如下所示。

# GitHub Actions 的名称
name: GitHub Actions SpringBoot Demo

# 当 master 分支发生 push 或者 pull request 事件时触发 action
on:
  push:
    branches: [ master ]
  pull_request:
    branches: [ master ]

# 指定 jobs
jobs:
  # build job
  build:

    # 指定运行在 ubuntu 上
    runs-on: ubuntu-latest
    steps:

    # 把仓库代码拉到 ubuntu 镜像上
    - uses: actions/checkout@v2

    # 指定 java 版本
    - name: Set up JDK 1.8
      uses: actions/setup-java@v1
      with:
          java-version: 1.8

    # 给 gradle 赋予可运行权限
    - name: Grant execute permission for gradlew
      run: chmod +x gradlew

    # 通过 gradle 打包我们的项目
    - name: Build with gradle
      run: ./gradlew build

    # 通过 Dockerfile 构建镜像
    - name: Build docker image
      run: docker build . -t {{ image_name:image_version }}
    
    # 登陆到我们自己的 docker registry
    - name: Login to aliyun docker image registry
      run: echo "${{ secrets.REGISTRY_PASSWORD }}" |  docker login --username=xxxxxx registry.cn-shenzhen.aliyuncs.com --password-stdin

    # 上传 docker 镜像
    - name: Push image to aliyun docker image registry
      run: docker push {{ image_name:image_version }}

    # 连接到远程服务器
    - name: Connect to server
      uses: webfactory/ssh-agent@v0.4.1
      with:
        ssh-private-key: ${{ secrets.SSH_PRIVATE_KEY }}
    
    # 初始化 knownhosts
    - name: Setup knownhosts
      run: ssh-keyscan {{ your host }} >> ~/.ssh/known_hosts

    # 触发服务器部署脚本
    - name: Trigger server deployment script
      run: ssh root@{{ your host }} "sh {{ your deployment bash script }}"

关于 Nginx 方面,相信各位小伙伴应该是十分熟悉了,这里就不过多赘述。直接贴上一份简单的配置文件。

server {
    listen 80;
    server_name {{ your domain }};

    location / {
           proxy_pass http://localhost:8080/;
           proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
           proxy_set_header X-Forwarded-Proto $scheme;
           proxy_set_header X-Forwarded-Port $server_port;
    }
}

测试 GitHub Actions

完成了上面这些步骤,我们到 SpringBoot 工程里修改一下代码并提交到 GitHub Repository。稍等一会儿再访问项目,查看一下效果!

@RestController
public class DemoController {
    @GetMapping("/")
    public String sayHello() {
        return "Hello GitHub Actions!Hello World!";
    }
}

到这里我们就成功完成了一个基础的 GitHub Actions 实践,以后小伙伴们修改完代码,Push 或者 PR 到 master 分支,GitHub Actions 就会自动完成我们设置好的构建步骤。非常的方便快捷!🎉🎉🎉

总结

这份基础的 GitHub Actions SpringBoot 实践仅供大家参考,如果遇到什么坑,也欢迎在评论区与我讨论。文章写的不好,请大家多多谅解 😂。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,076评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,658评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,732评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,493评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,591评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,598评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,601评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,348评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,797评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,114评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,278评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,953评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,585评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,202评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,180评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,139评论 2 352