之前写过一篇文章《再见 Jenkins!几行脚本搞定自动化部署,这款神器有点厉害!》, 讲的是应用 Gogs+Drone 来实现自动化部署。最近发现 Gitlab 的 CI/CD 性能也能实现自动化部署,用起来也挺简略!如果你应用的是 Gitlab 作为 Git 仓库的话,无妨试试它的 CI/CD 性能。本文还是以 SpringBoot 的自动化部署为例,实际下 Gitlab 的 CI/DI 性能,心愿对大家有所帮忙!
SpringBoot 实战电商我的项目 mall(50k+star)地址:https://github.com/macrozheng/mall
装置
通过 Gitlab 的 CI/CD 性能实现自动化部署,咱们须要装置 Gitlab、Gitlab Runner、Maven 这些服务。
装置 Gitlab
首先咱们来装置下 Gitlab,对 Gitlab 装置和应用不理解的敌人能够参考下《10 分钟搭建本人的 Git 仓库》。
- 应用如下命令运行 Gitlab 服务,这里须要留神的是增加了
hostname
属性,这样咱们就能够通过域名来拜访 Gitlab 了(为了防止一些不必要的麻烦),GITLAB_ROOT_PASSWORD
这个环境变量能够间接设置 Gitlab 中 root 账号的明码;
docker run --detach \
--hostname git.macrozheng.com \
--publish 10443:443 --publish 1080:80 --publish 1022:22 \
--name gitlab \
--restart always \
--volume /mydata/gitlab/config:/etc/gitlab \
--volume /mydata/gitlab/logs:/var/log/gitlab \
--volume /mydata/gitlab/data:/var/opt/gitlab \
-e GITLAB_ROOT_PASSWORD=12345678 \
gitlab/gitlab-ce:latest
- 咱们须要通过
git.macrozheng.com
这个域名来拜访 Gitlab,如果你没有域名的话,能够通过批改本机的 host 文件来实现;
192.168.7.134 git.macrozheng.com
- 因为咱们的 Gitlab 运行在
1080
端口上,咱们想要不加端口来拜访,能够应用 Nginx 来反向代理下,对 Nginx 不相熟的敌人能够看下《Nginx 的这些妙用,你必定有不晓得的!》,在 Nginx 的配置文件夹中增加git.conf
配置文件,内容如下:
server {
listen 80; # 同时反对 HTTP
server_name git.macrozheng.com; #批改域名
location / {
proxy_pass http://192.168.7.134:1080; # 设置代理服务拜访地址
index index.html index.htm;
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {root /usr/share/nginx/html;}
}
- 之后咱们就能够通过
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
,这个版本十分玲珑!
docker pull gitlab/gitlab-runner:alpine-bleeding
- 应用如下命令运行
gitlab-runner
;
docker run --name gitlab-runner --restart always \
-v /var/run/docker.sock:/var/run/docker.sock \
-v /mydata/gitlab-runner:/etc/gitlab-runner \
-d gitlab/gitlab-runner:alpine-bleeding
- 此时咱们如果查看
gitlab-runner
的容器日志的话,会发现如下谬误,config.toml
文件找不到,这个问题不用放心,当咱们将gitlab-runner
注册到 Gitlab 时,会主动生成该文件;
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
容器的外部;
docker exec -it gitlab-runner /bin/bash
- 在容器内应用如下命令注册 runner;
gitlab-runner register
- 注册时会呈现交互界面,提醒你输出注册地址、token、执行器类型等信息,ssh 执行器能近程执行 Linux 命令,十分好用,举荐应用这个!
- 注册实现后,咱们能够发现
config.toml
文件曾经生成,内容如下,当前想批改 runner 配置的时候,间接改这个文件就行了。
concurrent = 1
check_interval = 0
[session_server]
session_timeout = 1800
[[runners]]
name = "docker-runner"
url = "http://192.168.7.134:1080/"
token = "c2kpV6tX6woL8TMxzBUN"
executor = "ssh"
[runners.custom_build_dir]
[runners.cache]
[runners.cache.s3]
[runners.cache.gcs]
[runners.cache.azure]
[runners.ssh]
user = "root"
password = "123456"
host = "192.168.7.134"
port = "22"
- 在 Gitlab 的 CI/CD 设置中,咱们能够发现,有个 runner 胜利注册了!
装置 Maven
SpringBoot 我的项目打包须要依赖 Maven,咱们须要在服务器上先装置好它。
- 下载 Maven 的 Linux 安装包,下载地址:https://maven.apache.org/down…
- 下载实现后应用如下命令解压到指定目录;
cd /mydata
tar -zxvf apache-maven-3.8.1-bin.tar.gz
- 批改
/etc/profile
文件,增加环境变量配置:
export MAVEN_HOME=/mydata/apache-maven-3.8.1
export PATH=$PATH:$MAVEN_HOME/bin
- 通过查看 Maven 版本来测试是否装置胜利。
mvn -v
Maven home: /mydata/apache-maven-3.8.1
Java version: 1.8.0_292, vendor: AdoptOpenJDK, runtime: /mydata/java/jdk1.8/jre
Default locale: en_US, platform encoding: UTF-8
OS name: "linux", version: "3.10.0-957.el7.x86_64", arch: "amd64", family: "unix"
装置 JDK
CentOS 上默认装置的是 JRE,应用 Maven 须要装置 JDK。
- 下载 JDK 8,下载地址:https://mirrors.tuna.tsinghua…
- 下载实现后将 JDK 解压到指定目录;
cd /mydata/java
tar -zxvf OpenJDK8U-jdk_x64_linux_xxx.tar.gz
mv OpenJDK8U-jdk_x64_linux_xxx.tar.gz jdk1.8
- 在
/etc/profile
文件中增加环境变量JAVA_HOME
。
vi /etc/profile
# 在 profile 文件中增加
export JAVA_HOME=/mydata/java/jdk1.8
export PATH=$PATH:$JAVA_HOME/bin
# 使批改后的 profile 文件失效
. /etc/profile
应用
所有准备就绪,接下来通过 Gitlab 的 CI/CD 性能就能够实现 SpringBoot 利用的自动化部署了!
- 首先在我的项目的根目录下增加
.gitlab-ci.yml
文件,定义了两个工作,一个工作会将利用代码打包成 Jar 包并复制到指定目录,另一个工作会通过运行脚本run.sh
打包利用的 Docker 镜像并运行;
# 打包工作
build-job:
stage: build
# 指定标签,只有具备该标签的 runner 才会执行
tags:
- docker
script:
# 应用 Maven 打包
- mvn clean package
# 将 jar 包、Dockerfile、运行脚本复制到指定目录
- cp target/mall-tiny-gitlab-1.0-SNAPSHOT.jar /mydata/build/mall-tiny-gitlab-1.0-SNAPSHOT.jar
- cp Dockerfile /mydata/build/Dockerfile
- cp run.sh /mydata/build/run.sh
# 部署工作
deploy-job:
stage: deploy
tags:
- docker
script:
# 进入指定目录并执行运行脚本
- cd /mydata/build
- chmod +x run.sh
- ./run.sh
- 这里值得一提的是,默认状况下 runner 只会执行具备雷同标签的 Job,因为咱们对 Job 和 runner 都设置了标签为
docker
,所以咱们这里是能够执行的。如果你没有设置标签的话,须要在 runner 的编辑界面设置下让 runner 能够执行没有标签的 Job;
- 因为咱们的
gitlab-runner
采纳的是ssh
的执行器,它会登录到咱们指定的服务器,执行咱们在.gitlab-ci.yml
中定义的script
命令,在此之前还会先从 Git 仓库中获取代码,所以咱们还需批改下服务器上的 host 文件;
vim /etc/hosts
192.168.7.134 git.macrozheng.com
- 接下来就是要把脚本提交到 Git 仓库下来,提交后会在
Project->CI/CD->Pipelines
中发现正在执行的工作;
- 关上 Pipeline 的详情页面,能够发现咱们定义的两个工作都曾经执行胜利了;
- 关上 Job 的详情界面,咱们能够看到工作执行过程中输入的日志信息;
- 如果你想手动执行 Pipeline,而不是提交触发的话,能够在 Pipelines 页面点击
Run Pipeline
按钮即可;
- 运行胜利后,能够通过如下地址拜访我的项目:http://192.168.7.134:8088/swa…
总结
如果你用 Gitlab 作为 Git 仓库的话,应用它的 CI/CD 性能来实现自动化部署的确很不错!装置一个轻量级 gitlab-runner
,编写简略的.gitlab-ci.yml
脚本文件即可实现。其实咱们之前以及介绍过很多种自动化部署计划,比方 Jenkins、Gogs+Drone、Gitlab CI/CD,咱们能够发现一个共同点,这些计划都离不开 Linux 命令。所以说要想玩转自动化部署,还是得先玩转 Linux 命令!
参考资料
官网文档:https://docs.gitlab.com/ee/ci/
我的项目源码地址
https://github.com/macrozheng…
本文 GitHub https://github.com/macrozheng/mall-learning 曾经收录,欢送大家 Star!