暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

Gitlab CI 搭建持续集成环境实现Docker自动化部署使用Harbor镜像仓库

小东IT技术分享 2019-04-15
583

本文简单介绍了持续集成的概念并着重介绍了如何基于 Gitlab CI 快速构建持续集成环境以及使用Docker实现自动化部署,主要介绍了 Gitlab CI 的基本功能和入门操作流程

以Ubuntu16.04.4++Gitlab CI+Docker自动化部署SptingBoot项目+搭建Harbor镜像仓库

一. 概念

持续集成(Continuous Integration,简称CI)指的是,频繁地(一天多次)将代码集成到主干。持续集成的好处主要有两个:

  • 1.快速发现错误 每完成一点更新,就集成到主干,可以快速发现错误,定位错误也比较容易

  • 2.防止分支大幅偏离主干 如果不是经常集成,主干又在不断更新,会导致以后集成的难度变大,甚至难以集成。

持续集成的目的,就是让产品可以快速迭代,同时还能保持高质量。它的核心措施是,代码集成到主干之前,必须通过自动化测试。只要有一个测试用例失败,就不能集成。

二. 开始搭建

1.依赖包安装

sudo apt-get updatesudo apt-get install -y curl openssh-server ca-certificates

执行完成后,邮件配置时选择Internet即可.

2.GitLab安装

2.1官方教程

如果按照官方安装方法, 直接运行下列命令即可.

curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ee/script.deb.sh | sudo bashsudo apt-get install gitlab-ce

但按照官方教程安装会非常慢, 推荐使用下列方式, 利用清华源安装.

2.2清华源(推荐)

首先信任GitLab的GPG公钥

curl https://packages.gitlab.com/gpg.key 2> /dev/null | sudo apt-key add - &>/dev/null

接下来打开gitlab-ce.list文本

sudo vim /etc/apt/sources.list.d/gitlab-ce.list

然后写入如下内容

deb https://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/ubuntu xenial main

最后:wq保存退出. 文本写入成功之后, 执行下列命令安装GitLab.

sudo apt-get updatesudo apt-get install gitlab-ce

    

    

    

    出现以上界面说明安装成功

3.GitLab启动

安装完成之后启动GitLab

sudo gitlab-ctl reconfigure

打开sshd和postfix服务

service sshd startservice postfix start

最后输入下列命令, 检查GitLab是否成功运行.

sudo gitlab-ctl status

4.GitLab配置

4.1更改服务器IP地址

找到下列内容 我这边默认使用80端口 所以我只修改了external_url改为自己服务器地址

vim /etc/gitlab/gitlab.rbexternal_url http://192.168.201.170改为服务器的公网external_url http://你的ipnginx[listen_port] = 9091 #默认值即80端口 nginx[listen_port] = nilunicorn[port] = 9092#原值unicorn[port] = 8080

注意不要用8082,9090 端口,因为自带工具会用到

修改完后重新启动服务

gitlab-ctl reconfigure

检查是否正确运行

sudo gitlab-ctl status

gitlab的管理

关闭gitlab: # gitlab-ctl stop启动gitlab: # gitlab-ctl start重启gitlab: # gitlab-ctl restart

浏览器打开 http://172.17.1.107 wb页面并设置密

密码自定义设置 设置完之后 账号 root
密码 你刚才设置的
登录成功界面

我这边直接创建一个项目进行演示

在项目下面会有git的操作指南教你如何操作

至此,基于Ubuntu 16.04 x64操作系统的GitLab服务器搭建工作就完成了!具体详细教程可以看我这篇文章 

GitLab 的介绍与安装配置
https://www.lhdyx.cn/article/75


本地操作git 在本地创建一个文件夹即可 命令就是官网的

下面我们操作我们的项目就是这样的 为下面打基础 现在安装Gitlba-Runner

二. Gitlab-Runner安装

curl https://packages.gitlab.com/gpg.key 2> /dev/null | sudo apt-key add - &>/dev/null

再选择你的 Ubuntu 版本,将下面的配置内容写进

vim /etc/apt/sources.list.d/gitlab-ci-multi-runner.list

文件不存在就新建该文件

deb https://mirrors.tuna.tsinghua.edu.cn/gitlab-ci-multi-runner/ubuntu xenial main

安装 gitlab-ci-multi-runner:

sudo apt-get updatesudo apt-get install gitlab-ci-multi-runner

启动gitlab-runner

gitlab-runner start


注册gitlab-runner 打开gitlab网站找到自己的项目下面的Runnnner


最主要的我们需要这些信息注册 执行注册命令

gitlab-runner register

   

参数解释:

绿色说明注册成功 这个时候我们就可以通过runner进行操作 四. 编写编写.gitlab-ci.yml文件 一般配置完Runner后都会有这个直接点击创建

内容为

  1. stages:

  2.  - deploy


  3. docker-deploy:

  4.  stage: deploy

  5.  # 执行Job内容

  6.  script:

  7.    - echo 开始构建....

  8.    - cd springboot-thymeleaf

  9.    - echo 构建中....

  10.    - mvn clean package

  11.    - cd target/alpine-hwlogs/

  12.    - docker build -t springboot .

  13.    - echo 构建成功....

  14.    - echo 发布中....

  15.    - docker run -d -p 8000:8000 --name springboot springboot

  16.    - echo 发布中成功!

  17.  only:

  18.    # 只有在master分支才会执行

  19.    - master


    

大概意思为 进到项目路径打包创建docker镜像 然后运行

四.安装java1.8和 maven以及Docker

简单说下步骤

1. 安装java1.8

添加ppa
sudo add-apt-repository ppa:webupd8team/javasudo apt-get update
安装oracle-java-installer
sudo apt-get install oracle-java8-installer
设置系统默认jdk
sudo update-java-alternatives -s java-8-oracle
java安装测试
java -versionjavac -version


安装成功

2. 安装maven

1. 下载imaven的tar.gz安装包,下载路径如下:
http://maven.apache.org/download.cgi
2. 将压缩包复制到 /usr/local/maven 目录下(这个自定义的)
apache-maven-3.6.0-bin.tar.gz /usr/local/
3. 解压安装包
tar -zxvf apache-maven-3.6.0-bin.tar.gz
4. 设置环境变量
vim /etc/profile
在profile文件中加入如下内容:
export M2_HOME=/usr/local/maven/apache-maven-3.6.0export PATH=$M2_HOME/bin:$PATHexport CLASSPATH=.:$M2_HOME/lib

刷新

source /etc/profile
安装测试
mvn -v

3.安装Docker

前提条件 Docker 要求 Ubuntu 系统的内核版本高于 3.10 ,查看本页面的前提条件来验证你的 Ubuntu 版本是否支持 Docker。通过 uname -r 命令查看你当前的内核版本

runoob@runoob:~$ uname -r

使用脚本安装 Docker 1、获取最新版本的 Docker 安装包

wget -qO- https://get.docker.com/ | sh

输入当前用户的密码后,就会下载脚本并且安装Docker及依赖包。

安装完成后有个提示:

  1.    If you would like to use Docker as a non-root user, you should now consider

  2.    adding your user to the docker group with something like:


  3.    sudo usermod -aG docker runoob

  4.   Remember that you will have to log out and back in for this to take effect!  

当要以非root用户可以直接运行docker时,需要执行 sudo usermod -aG docker runoob 命令,然后重新登陆,否则会有如下报错

2、启动docker 后台服务

runoob@runoob:~$ sudo service docker start

3、测试运行hello-world

runoob@runoob:~$ docker run hello-world

因为没有镜像 需要去下载 镜像加速 鉴于国内网络问题,后续拉取 Docker 镜像十分缓慢,我们可以需要配置加速器来解决,我使用的是网易的镜像地址:

http://hub-mirror.c.163.com

新版的 Docker 使用 /etc/docker/daemon.json(Linux) 或者 %programdata%\docker\config\daemon.json(Windows) 来配置 Daemon

请在该配置文件中加入(没有该文件的话,请先建一个):

{  registry-mirrors: [http://hub-mirror.c.163.com]}

五. 项目准备

准备一个SpringBoot项目并编写Dockerfile文件以及maven插件操作

1.SpringBoot项目: 一个简单项目 访问返回信息
2.Dockerfile内容如下

  1. #  基础镜像

  2. FROM java:openjdk-8-jre-alpine

  3. # 维护者信息

  4. MAINTAINER lihaodongmail@163.com

  5. #Default to UTF-8 file.encoding

  6. ENV LANG C.UTF-8

  7. #设置alpine时区

  8. ENV TIMEZONE Asia/Shanghai

  9. #alpine自带的包含dl-cdn的域名非常慢,需要修改后才能下载数据。

  10. #RUN apk add -U tzdata && ln -snf /usr/share/zoneinfo/${TIMEZONE} /etc/localtime && echo ${TIMEZONE} > /etc/timezone

  11. #RUN sed -i -e s/dl-cdn/dl-4/g /etc/apk/repositories && apk add -U tzdata && ln -snf /usr/share/zoneinfo/${TIMEZONE} /etc/localtime && echo ${TIMEZONE} > /etc/timezone


  12. #添加应用

  13. ADD springboot-thymeleaf-0.0.1-SNAPSHOT.jar springboot-thymeleaf-0.0.1-SNAPSHOT.jar

  14. #参数

  15. #ENV PARAMS=

  16. #执行操作

  17. ENTRYPOINT [ sh, -c, java -Xmx50m -Djava.security.egd=file:/dev/./urandom -jar springboot-thymeleaf-0.0.1-SNAPSHOT.jar ]

3.然后运用maven插件

  1. <plugin>

  2.                <artifactId>maven-resources-plugin</artifactId>

  3.                <executions>

  4.                    <execution>

  5.                        <id>copy-resources</id>

  6.                        <phase>validate</phase>

  7.                        <goals>

  8.                            <goal>copy-resources</goal>

  9.                        </goals>

  10.                        <configuration>

  11.                            <outputDirectory>${project.build.directory}/alpine-hwlogs</outputDirectory>

  12.                            <resources>

  13.                                <resource>

  14.                                    <directory>src/main/docker</directory>

  15.                                    <filtering>true</filtering>

  16.                                </resource>

  17.                            </resources>

  18.                        </configuration>


  19.                    </execution>

  20.                </executions>

  21.            </plugin>

  22.            <!-- copy文件 -->

  23.            <plugin>

  24.                <groupId>org.apache.maven.plugins</groupId>

  25.                <artifactId>maven-antrun-plugin</artifactId>

  26.                <executions>

  27.                    <execution>

  28.                        <phase>package</phase>

  29.                        <goals>

  30.                            <goal>run</goal>

  31.                        </goals>

  32.                        <configuration>

  33.                            <tasks> <!-- 你将要拷贝的位置 -->

  34.                                <copy todir=${project.build.directory}/alpine-hwlogs>

  35.                                    <!-- 从哪里拷贝 -->

  36.                                    <fileset dir=${project.build.directory}>

  37.                                        <!-- 拷贝内容 -->

  38.                                        <include name=*.jar/>  

  39.                                    </fileset>

  40.                                </copy>

  41.                            </tasks>

  42.                        </configuration>

  43.                    </execution>

  44.                </executions>

  45.            </plugin>

大概意思为打包时在target下创建lpine-hwlogs文件夹并把Dockerfile文件,打包好的jar包copy到lpine-hwlogs目录下

六.上传GitLab测试

现在我把SpringBoot项目上传到GitLab看下效果

过程就是把项目push到gitlab仓库 现在打开gitlab看下我们的runner有没有执行

已经在执行我写的脚本 maven打包下载依赖等 稍等一会

说我没有权限 才想起来 运行gitlab-runnner的是gitlab-runnner用户

添加gitlab-runner用户 重启docker 然后重试任务

再次查看运行情况

已经搞定

登录服务查看镜像情况以及浏览器服务测试下

打开浏览器访问: http://172.17.1.107:8000/index

搞定!

七. 安装Harbor搭建镜像仓库

官方文档:https://github.com/goharbor/harbor/blob/master/docs/installation_guide.md

1 环境依赖:docker docker-compose

1.1 下载docker:

Ubuntu16 可参考 https://blog.csdn.net/jinking01/article/details/82490688

其它系统可参考:http://www.runoob.com/docker/ubuntu-docker-install.html

我的服务器是在阿里云上,直接运行:

apt-get install docker.io

 注:

检测安装结果:docker -v

1.2 下载docker-compose

阿里云上:apt-get install docker-compose

官网教程参考:https://docs.docker.com/compose/install/#install-compose

1.2.1 官网解决方案一(Linux):(问题:我遇到问题就是下载速度太慢)

sudo curl -L https://github.com/docker/compose/releases/download/1.23.2/docker-compose-$(uname -s)-$(uname -m) -o /usr/local/bin/docker-composesudo chmod +x /usr/local/bin/docker-compose`

1.2.2 官网解决方案二:用python的pip工具

pip install docker-compose

注:

检测安装情况:

docker-compose --version

1.3 下载Harbor

官网地址:https://github.com/goharbor/harbor/releases

1.3.1 复制地址,运行wget url:

wget https://storage.googleapis.com/harbor-releases/release-1.7.0/harbor-online-installer-v1.7.1.tgz

注:下载速度太慢,可以windows上下载下来然后copy到服务器上 创建 /usr/local/harbor文件夹 然后授权

将下载的包传到服务器解压即可

1.3.2 解压:

tar -xvf harbor-online-installer-v1.7.1.tgz


2 配置harbor

2.1 修改harbor.cfg

cd harborvim harbor.cfg

将 hostname的值修改成本机IP,比如198.127.0.1

部分配置含义:

#配置访问的地址hostname = 198.127.0.1#使用http方式访问管理界面ui_url_protocol = http#配置admin的密码,默认是Harbor12345harbor_admin_password = 12345#更改harbor存储路径,默认是/datasecretkey_path = /mnt/vdc/harbor_data

2.2 开始安装:

./install.sh

docker要pull很多东西 等下就好了

发现启动nginx发现报错 我们都知道默认80端口  那需要修改harbor里的nginx的默认端口配置:

第一种:

2.3.1 修改docker-compose.yml

vim docker-compose.yml

例如 修改80:80 为 81:80

2.3.2修改config.xml,在$publicurl()后增加 :81

vim common/templates/registry/config.yml

2.3.3重新生成配置文件

sudo ./prepare

2.4 启动Harbor:

docker-compose up -d

停止命令

docker-compose down -v

2.4.1 进入Harbor的UI界面

(端口默认是80,nginx如果修改了端口映射(比如上面的81:80),那端口就是81):IP:Port

Eg: 172.17.101:81

Harbor默认用户名:adminHarbor

默认密码:Harbor12345

我之前有做修改为123456

登录成功后

创建一个test项目

既然Harbor搭建完成了 test项目也新建完成了 那我们就需要将docker的镜像上传到我们的私仓里

在我们之前装的docker修改insecure-registry

文件目录:/etc/docker/daemon.json (没有则新建该文件)

vim /etc/docker/daemon.json

然后重启docker:

service docker restart

docker push镜像:

登录Harbor
docker login 172.17.1.101:81

输入

用户名admin密码12345

登录成功后 我们把之前的springboot镜像上传到Harbor

使用镜像源创建一个指定镜像的标签 推送镜像到Harbor

八 查看成果

登录Harbor 查看test项目

完美!然后就可以随意push pull了

本文测试SpringBoot项目源码: 

https://github.com/LiHaodong888/dockerexample


文章转载自小东IT技术分享,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论