您好,登錄后才能下訂單哦!
小編給大家分享一下如何基于spring-boot和docker-java實現對docker容器的動態管理和監控功能,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
docker簡介
Docker 是一個開源的應用容器引擎,和傳統的虛擬機技術相比,Docker 容器性能開銷極低,因此也廣受開發者喜愛。隨著基于docker的開發者越來越多,docker的鏡像也原來越豐富,未來各種企業級的完整解決方案都可以直接通過下載鏡像拿來即用。因此docker變得越來越重要。
本文目的
本文通過一個項目實例來介紹如果通過docker對外接口來實現對docker容器的管理和監控。
應用場景:
對服務器資源池通過docker進行統一管理,按需分配資源和創建容器,達到資源最大化利用。同時保證各業務(容器)之間的隔離。并可支持項目的在線部署。
本項目模擬實現以上場景,代碼不完全嚴禁,代碼僅供學習。
吧本文
1、通過界面創建docker的tomcat容器,并配置限額。
2、上傳war包并部署到容器。
3、動態監控docker所有容器的資源使用情況。
代碼基于docker-java開源組件,基于spring-boot完成功能開發。界面如下圖:
基礎環境
1、eclipse 2019-03;
2、docker for windows。本著學習和簡單的目的,并未使用linux環境,但原理和基本命令相同。
相關技術和知識點:
maven,spring-boot;spring mvc;spring上傳下載,jquery ajax和上傳。
實現原理
docker對外提供了豐富接口(如:restfull APi),通過這些接口可對docker進行管理。docker-java開源組件基于這個接口做了封裝,使得開發更加簡單。當然市面上還有其他一些封裝好的組件,大家可自行比較和學習。在這里對開源作者表示感謝。
實現過程之前期準備
1、升級windows
由于我們使用的是windows環境, 筆者自己電腦預裝的是win10 家庭版,而docker for windows 需要運行在更高級別的操作系統上,才能使用虛擬化技術,因此需要升級到專業版。
如果需要升級的,升級過程也比較簡單,簡單介紹如下(已經是專業版的可以略過):
點擊更改產品密匙,輸入專業版的密匙之后,就等待慢慢升級了。密匙自己在網上找,反正是有的。
2、安裝docker for windows
去官網下載后,一路下一步就可以了。安裝完后,會自己啟動,啟動后工具欄就會出現docker的標志。
安裝成功后,可以敲一些命令測試一下是否成功。如:查看docker基本信息。
3、修改docker鏡像地址。
由于默認的鏡像地址較慢,一個tomcat鏡像都500多m,網絡不好下載會很慢,可將鏡像地址配置成網易的鏡像地址,如下:
4、啟動遠程管理
勾選上最后一項,這里面的tcp//xxx就是遠程連接地址。
啟動后,在瀏覽器里面敲一下地址,看看是否能返回結果:
http://localhost:2375/info(此地址同在cmd里面輸入docker indo)返回的是json格式的內容:
實現過程之代碼開發
1、創建maven項目。
由于過程簡單,省略此過程。整個項目的代碼結構如下:
2、配置docker-java和spring boot的maven依賴,最終pom文件內容如下
通過看jar包,docker-java底層應該是用了netty依賴。
3、添加spring配置文件application.properties
配置jsp的位置和docker的管理地址。
4、主要類介紹:
1.spring boot啟動主類。
當然也可以配置其他容器或者用maven的jetty插件來啟動。
可參考另外一篇文章:Spring-boot原理(附帶實現一個spring-boot-starter實例)附源碼下載
注意這個類放的位置,最好放在根目錄,這樣根目錄下的所有子目錄都能被spring掃描到了。
2.DockerClientOperaterServer(與docker交互的類),具體如下:
包括如下方法:
initClient:初始化鏈接。
getDockerInfo:獲取docker基本信息;
stat:實時統計信息;
refreshContainers:獲取所有容器的基本信息,并放入緩存;
createAndStartrContainerAnddeployApp:根據界面傳遞的參數創建并啟動容器,同時部署項目;
stopContainer:停止容器;
rmContainer:刪除容器;
closeClient:關閉鏈接;
pushAppToCotainer:部署war包到tomcat;
由于代碼片段太長,這里看幾個主要的方法:
createContainer(創建容器):
這個方法里面通過docker-java創建容器,分配限額,配置端口映射等。
pushAppToCotainer:部署項目到tomcat
stat,監控方法:
監控這一塊沒有用docker-java的方法,其實它是支持的,但是由于返回結果需要各種處理,就用了投機取巧的方法。使用java調用cmd來執行(docker stats)獲取監控結果。
docker-java來獲取監控信息的代碼如下:
3.DockerClientController(和界面交互的controller)。
主要方法介紹:
addContainer:添加容器以及上傳war包
以上便是主要代碼的講解。
具體代碼詳情,請下載源碼啟動后按照過程查看。
實現后的主要界面:
由于是示例項目,代碼沒有用什么vue和bootstrap框架。自己寫了點css和js。具體效果如下:
1、監控管理主頁
2、添加容器;
以上是“如何基于spring-boot和docker-java實現對docker容器的動態管理和監控功能”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。