MiniMall:Linux環境下持續集成(基於Docker+Jenkins)

MiniMall項目的部署篇,到目前爲止,我們說了《Windows環境下的部署》《Linux環境下的部署(基於Docker)》《Linux環境下的部署(基於Docker Compose)》。每種部署方式都是循序漸進的,從Windows到Linux服務器,從Docker到Docker Compose。但這幾種部署方式都有一個特點,就是部署微服務的工程的時候都要先打成jar包,然後上傳到服務器,再手動執行部署。

手動去部署,這是一件非常耗時且容易出錯的事。而且這也是不現實的部署方式,假設有100個微服務工程,手動一個個部署,這是多麼荒唐的一件事。所以很有必要有一種方式,能夠定時或者在我們提交代碼到版本控制庫的時候自動打包、編譯、完成部署,通常我們把這種方式稱爲持續集成。而在市場上Jenkins無疑是當前最流行的持續集成工具之一。

1. 部署環境

服務器
Docker、Harbor(鏡像倉庫) Linux(192.168.1.17)
Jenkins Windows

因爲開發環境是在Windows,且Maven的私服也在Windows,所以爲了加快Jenkins編譯過程下載jar包的速度,Jenkins也部署在Windows上。

2. 部署流程

我們的部署過程是這樣的:

(1)從版本控制庫中拉取最新的代碼,然後打包編譯;

(2)刪除舊的鏡像,然後構建新的鏡像;

(3)將構建好的新的鏡像推送到鏡像倉庫(Harbor)中;

(4)停止相應的容器,並刪除對應的容器;

(5)根據新的鏡像創建新的容器並啓動容器。

3. 開始部署

3.1 開啓Docker外部訪問

  • 使用vim命令編輯Docker文件
vim /usr/lib/systemd/system/docker.service
  • 修改ExecStart行的內容(直接將以下內容拼到後面)
-H tcp://0.0.0.0:2375 -H unix://var/run/docker.sock

ExecStart行完整內容:

ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock -H tcp://0.0.0.0:2375 -H unix://var/run/docker.sock
  • 重新加載docker配置
# 1. 加載docker守護進程
systemctl daemon-load
# 2. 重啓docker
systemctl restart docker

3.2 搭建Docker鏡像倉庫

我們使用Harbor作爲鏡像倉庫,搭建過程這裏不細說了,後面會專開一個專題來說說Docker的一些東西。Harbor的默認端口是80,這裏我們把它修改成85。登錄進去,進入到項目列表頁(library是默認的項目,minimall是我們自己創建的一個私有項目)。

在這裏插入圖片描述

點擊minimall項目,然後查看當前鏡像倉庫,可以看到當前是沒有任何鏡像的。後面Jenkins持續集成時,就會將一個個微服務工程鏡像推送到這邊來。

在這裏插入圖片描述

3.3 修改微服務工程pom文件

我們以服務註冊中心(mall-registry-server)舉例,在pom文件中添加docker-maven-plugin插件。

  • properties屬性
<properties>
    <!--docker插件-->
    <!-- docker鏡像倉庫地址,Harbor默認地址就是80,如果是默認可以不帶端口號 -->
    <docker.repository.url>192.168.1.17:85</docker.repository.url>
    <!-- 項目名,需要和Harbor中的項目名稱保持一致 -->
    <docker.repository.name>minimall</docker.repository.name>
</properties>
  • plugin插件
<plugin>
    <groupId>com.spotify</groupId>
    <artifactId>docker-maven-plugin</artifactId>
    <version>1.1.0</version>
    <configuration>
        <!--Maven的setting.xml中server的id,配置的是harbor的用戶名和密碼-->
        <serverId>harbor-server</serverId>
        <!--Docker鏡像倉庫地址-->
        <registryUrl>http://${docker.repository.url}</registryUrl>
        <!--Docker所在的機器ip和端口(必須配置dockerHost標籤(除非配置系統環境變量DOCKER_HOST))-->
        <dockerHost>http://192.168.1.17:2375</dockerHost>
        <!--Docker鏡像名稱,格式:倉庫ip:倉庫端口/倉庫項目名稱/鏡像名-->
        <imageName>
            ${docker.repository.url}/${docker.repository.name}/${project.artifactId}:${project.version}
        </imageName>
        <!--依賴的基礎鏡像-->
        <baseImage>openjdk:8-jdk-alpine</baseImage>
        <!--執行程序-->
        <entryPoint>["java", "-jar", "/${project.build.finalName}.jar"]</entryPoint>
        <!--強制覆蓋上次推送的重名tag鏡像-->
        <forceTags>true</forceTags>
        <!--jar包位置-->
        <resources>
            <resource>
                <targetPath>/</targetPath>
                <!--當前工程的target目錄-->
                <directory>${project.build.directory}</directory>
                <!--jar包名-->
                <include>${project.build.finalName}.jar</include>
            </resource>
        </resources>
    </configuration>
</plugin>

其中serverId是在Maven的setting.xml中配置的server的id:

<server>
    <id>harbor-server</id>
    <username>admin</username>
    <password>Harbor12345</password>
    <configuration>
        <email>[email protected]</email>
    </configuration>
</server>

3.4 Jenkins添加docker-build-step插件

在這裏插入圖片描述

3.5 Jenkins添加Harbor用戶憑據

在這裏插入圖片描述

3.6 新建一個Maven項目mall-registry-server

在這裏插入圖片描述

  • 源碼管理

在這裏插入圖片描述

  • 構建前配置:停止容器、並刪除容器

在這裏插入圖片描述

  • 構建配置:打包、刪除鏡像、構建鏡像、上傳鏡像到私有倉庫

在這裏插入圖片描述

  • 構建後配置

    • 拉取鏡像

在這裏插入圖片描述

  • 創建容器

在這裏插入圖片描述

  • 啓動容器

在這裏插入圖片描述

3.7 開始構建

構建的很簡單,點一下按鈕就好了。構成成功之後,控制檯輸出以下內容:

在這裏插入圖片描述

4. 測試

  • 查看私有鏡像倉庫已經有一個mall-registry-server的鏡像

在這裏插入圖片描述

  • 瀏覽器訪問服務註冊中心

在這裏插入圖片描述

以上就是mall-registry-server這個工程的持續集成過程。其它微服務工程也都是大同小異的,這裏就不一一羅列了。

——End——
更多精彩分享,可掃碼關注微信公衆號哦。

在這裏插入圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章