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
這個工程的持續集成過程。其它微服務工程也都是大同小異的,這裏就不一一羅列了。