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就是遠端連線位址。
啟動後,在瀏覽器裡面敲一下位址,看看是否能回傳結果:
(此位址同在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、新增容器;
以上是基於springboot和docker-java怎麼實現對docker容器的動態管理和監控功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!