SpringBoot实战电商项目mall(50k+star)地址:github.com/macrozheng/…
摘要
之前写过一篇文章《再见 Jenkins !几行脚本搞定自动化部署,这款神器有点厉害!》 ,讲的是使用Gogs+Drone来实现自动化部署。最近发现Gitlab的CI/CD功能也能实现自动化部署,用起来也挺简单!如果你使用的是Gitlab作为Git仓库的话,不妨试试它的CI/CD功能。本文还是以SpringBoot的自动化部署为例,实践下Gitlab的CI/DI功能,希望对大家有所帮助!
安装
通过Gitlab的CI/CD功能实现自动化部署,我们需要安装Gitlab、Gitlab Runner、Maven这些服务。
安装Gitlab
首先我们来安装下Gitlab,对Gitlab安装和使用不了解的朋友可以参考下《10分钟搭建自己的Git仓库》 。
- 使用如下命令运行Gitlab服务,这里需要注意的是添加了
hostname
属性,这样我们就可以通过域名来访问Gitlab了(为了避免一些不必要的麻烦),GITLAB_ROOT_PASSWORD
这个环境变量可以直接设置Gitlab中root账号的密码;
1 | bash复制代码docker run --detach \ |
- 我们需要通过
git.macrozheng.com
这个域名来访问Gitlab,如果你没有域名的话,可以通过修改本机的host文件来实现;
1 | 复制代码192.168.7.134 git.macrozheng.com |
- 由于我们的Gitlab运行在
1080
端口上,我们想要不加端口来访问,可以使用Nginx来反向代理下,对Nginx不熟悉的朋友可以看下《Nginx的这些妙用,你肯定有不知道的!》 ,在Nginx的配置文件夹中添加git.conf
配置文件,内容如下:
1 | ini复制代码server { |
- 之后我们就可以通过
git.macrozheng.com
这个域名来访问Gitlab了,输入账号密码root:12345678
即可登录;
- 将我们的SpringBoot应用代码上传到Gitlab上去,这样Gitlab就准备完毕了!这里需要注意的是,如果你在启动Gitlab的时候没有指定
hostname
的话,你的项目HTTP访问地址会是容器的ID,使用该地址会无法访问Git仓库!
安装Gitlab Runner
Gitlab只是个代码仓库,想要实现CI/CD还需安装
gitlab-runner
,gitlab-runner
相当于Gitlab中任务的执行器,Gitlab会在需要执行任务时调用它。
- 首先下载
gitlab-runner
的Docker镜像,选用alpine-bleeding
,这个版本非常小巧!
1 | bash复制代码docker pull gitlab/gitlab-runner:alpine-bleeding |
- 使用如下命令运行
gitlab-runner
;
1 | bash复制代码docker run --name gitlab-runner --restart always \ |
- 此时我们如果查看
gitlab-runner
的容器日志的话,会发现如下错误,config.toml
文件找不到,这个问题不必担心,当我们将gitlab-runner
注册到Gitlab时,会自动生成该文件;
1 | bash复制代码ERROR: Failed to load config stat /etc/gitlab-runner/config.toml: no such file or directory builds=0 |
- 接下来我们需要把
gitlab-runner
注册到Gitlab,打开Project->Settings->CI/CD
功能,获取到runner注册需要使用的地址和token;
- 接下来使用如下命令,进入
gitlab-runner
容器的内部;
1 | bash复制代码docker exec -it gitlab-runner /bin/bash |
- 在容器内使用如下命令注册runner;
1 | bash复制代码gitlab-runner register |
- 注册时会出现交互界面,提示你输入注册地址、token、执行器类型等信息,ssh执行器能远程执行Linux命令,非常好用,推荐使用这个!
- 注册完成后,我们可以发现
config.toml
文件已经生成,内容如下,以后想修改runner配置的时候,直接改这个文件就行了。
1 | ini复制代码concurrent = 1 |
- 在Gitlab的CI/CD设置中,我们可以发现,有个runner成功注册了!
安装Maven
SpringBoot项目打包需要依赖Maven,我们需要在服务器上先安装好它。
- 下载Maven的Linux安装包,下载地址:maven.apache.org/download.cg…
- 下载完成后使用如下命令解压到指定目录;
1 | bash复制代码cd /mydata |
- 修改
/etc/profile
文件,添加环境变量配置:
1 | bash复制代码export MAVEN_HOME=/mydata/apache-maven-3.8.1 |
- 通过查看Maven版本来测试是否安装成功。
1 | bash复制代码mvn -v |
1 | bash复制代码Maven home: /mydata/apache-maven-3.8.1 |
安装JDK
CentOS上默认安装的是JRE,使用Maven需要安装JDK。
- 下载JDK 8,下载地址:mirrors.tuna.tsinghua.edu.cn/AdoptOpenJD…
- 下载完成后将JDK解压到指定目录;
1 | bash复制代码cd /mydata/java |
- 在
/etc/profile
文件中添加环境变量JAVA_HOME
。
1 | bash复制代码vi /etc/profile |
使用
一切准备就绪,接下来通过Gitlab的CI/CD功能就可以实现SpringBoot应用的自动化部署了!
- 首先在项目的根目录下添加
.gitlab-ci.yml
文件,定义了两个任务,一个任务会将应用代码打包成Jar包并复制到指定目录,另一个任务会通过运行脚本run.sh
打包应用的Docker镜像并运行;
1 | yaml复制代码# 打包任务 |
- 这里值得一提的是,默认情况下runner只会执行具有相同标签的Job,由于我们对Job和runner都设置了标签为
docker
,所以我们这里是可以执行的。如果你没有设置标签的话,需要在runner的编辑界面设置下让runner可以执行没有标签的Job;
- 由于我们的
gitlab-runner
采用的是ssh
的执行器,它会登录到我们指定的服务器,执行我们在.gitlab-ci.yml
中定义的script
命令,在此之前还会先从Git仓库中获取代码,所以我们还需修改下服务器上的host文件;
1 | bash复制代码vim /etc/hosts |
- 接下来就是要把脚本提交到Git仓库上去,提交后会在
Project->CI/CD->Pipelines
中发现正在执行的任务;
- 打开Pipeline的详情页面,可以发现我们定义的两个任务都已经执行成功了;
- 打开Job的详情界面,我们可以看到任务执行过程中输出的日志信息;
- 如果你想手动执行Pipeline,而不是提交触发的话,可以在Pipelines页面点击
Run Pipeline
按钮即可;
- 运行成功后,可以通过如下地址访问项目:http://192.168.7.134:8088/swagger-ui/
总结
如果你用Gitlab作为Git仓库的话,使用它的CI/CD功能来实现自动化部署确实很不错!安装一个轻量级gitlab-runner
,编写简单的.gitlab-ci.yml
脚本文件即可实现。其实我们之前以及介绍过很多种自动化部署方案,比如Jenkins、Gogs+Drone、Gitlab CI/CD,我们可以发现一个共同点,这些方案都离不开Linux命令。 所以说要想玩转自动化部署,还是得先玩转Linux命令!
参考资料
项目源码地址
本文 GitHub github.com/macrozheng/… 已经收录,欢迎大家Star!
本文转载自: 掘金