摘要:它是目前最流行的容器解決方案。創建文件在中加入以下信息注意必須和包在同一路徑下基礎鏡像必要,代表你的項目將構建在這個基礎上面允許指定端口轉發創建一個可以從本地主機或其他容器掛載的掛載點,一般用來存放數據庫和需要保持的數據等。
1.簡介
建議閱讀本文最好對Dokcer有一些了解首先我們先了解一下Docker是什么
Docker 屬于 Linux 容器的一種封裝,提供簡單易用的容器使用接口。它是目前最流行的 Linux 容器解決方案。
Docker 將應用程序與該程序的依賴,打包在一個文件里面。運行這個文件,就會生成一個虛擬容器。程序在這個虛擬容器里運行,就好像在真實的物理機上運行一樣。有了 Docker,就不用擔心環境問題。
總體來說,Docker 的接口相當簡單,用戶可以方便地創建和使用容器,把自己的應用放入容器。容器還可以進行版本管理、復制、分享、修改,就像管理普通的代碼一樣。
提供一次性的環境
提供彈性的云服務
組建微服務架構
如何搭建Docker環境使用yum安裝
#查看你當前的內核版本 uname -r #安裝 Docker yum -y install docker #啟動 Docker 后臺服務 service docker start #測試運行 hello-world,由于本地沒有hello-world這個鏡像,所以會下載一個hello-world的鏡像,并在容器內運行。 docker run hello-world
腳本安裝:
#確保 yum 包更新到最新 sudo yum update #執行 Docker 安裝腳本,執行這個腳本會添加 docker.repo 源并安裝 Docker。 curl -fsSL https://get.docker.com/ | sh #啟動 Docker 進程 sudo service docker start #驗證 docker 是否安裝成功并在容器中執行一個測試的鏡像 sudo docker run hello-world
因為國內下載鏡像速度較慢,推薦使用替換為國內的鏡像源
執行命令
vim /etc/docker/daemon.json 加入以下代碼 { "registry-mirrors": ["2.創建項目"] }
首先我們先創建一個SpringBoot的項目,這個步驟就不在重復了,可以使用IDEA構建或者訪問SpringBoot項目來進行構建項目。
完整的項目結構:
boot-docker ├── pom.xml └── src ├── main │ ├── java │ │ └── com │ │ └── example │ │ └── bootdocker │ │ └── BootDockerApplication.java │ └── resources │ ├── application.properties │ ├── static │ └── templates
然后創建一個控制器,這里不做的太復雜,主要就是來演示Docker怎么部署項目。
主要代碼:
啟動然后打開瀏覽器訪問接口地址:
項目完成,現在開始部署到Docker中。
3.部署項目 3.1 使用Dockerfile在部署項目之前我們要先了解一下Dockerfile 是什么?
Dockfile是一種被Docker程序解釋的腳本,Dockerfile由一條一條的指令組成,每條指令對應Linux下面的一條命令。Docker程序將這些Dockerfile指令翻譯真正的Linux命令。Dockerfile有自己書寫格式和支持的命令,Docker程序解決這些命令間的依賴關系,類似于Makefile。Docker程序將讀取Dockerfile,根據指令生成定制的image。相比image這種黑盒子,Dockerfile這種顯而易見的腳本更容易被使用者接受,它明確的表明image是怎么產生的。有了Dockerfile,當我們需要定制自己額外的需求時,只需在Dockerfile上添加或者修改指令,重新生成image即可,省去了敲命令的麻煩。參考
我們先把項目進行打包執行,執行。
mvn package
創建Dockerfile文件
touch Dockerfile
在Dockerfile中加入以下信息:
注意Dockerfile必須和Jar包在同一路徑下
FROM java:8 EXPOSE 8080 VOLUME /slm ADD boot-docker-0.0.1-SNAPSHOT.jar boot-docker.jar RUN sh -c "touch /boot-docker.jar" ENV JAVA_OPTS="" ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /boot-docker.jar" ]
FROM 基礎鏡像必要,代表你的項目將構建在這個基礎上面
EXPOSE 允許指定端口轉發
VOLUME 創建一個可以從本地主機或其他容器掛載的掛載點,一般用來存放數據庫和需要保持的數據等。
ADD 將文件從路徑
ENV 可以用于為docker容器設置環境變量
ENTRYPOINT 指定 Docker image 運行成 instance (也就是 Docker container) 時,要執行的命令或者文件。
CMD 和 ENTRYPOINT 都能用來指定開始運行的程序,而且這兩個命令都有兩種不用的語法:
CMD ["ls",""-l"] CMD ls -l
開始構建:
docker build -t boot-docker .
-t boot-docker 代表你要構建的名字
更多參數輸入查看:docker build --help
控制臺輸出:
Sending build context to Docker daemon 16.81MB Step 1/7 : FROM java:8 ---> d23bdf5b1b1b Step 2/7 : EXPOSE 8080 ---> Using cache ---> b2445bf62da8 Step 3/7 : VOLUME /slm ---> Using cache ---> b73d0b73b868 Step 4/7 : ADD boot-docker-0.0.1-SNAPSHOT.jar boot-docker.jar ---> Using cache ---> 2b4868aafca9 Step 5/7 : RUN sh -c "touch /boot-docker.jar" ---> Using cache ---> 816b59f199af Step 6/7 : ENV JAVA_OPTS="" ---> Using cache ---> 784f033b9dd6 Step 7/7 : ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /boot-docker.jar" ] ---> Using cache ---> 92a0da91ea19 Successfully built 92a0da91ea19 Successfully tagged bootdocker:latest
我們可以看到已經構建完成,Successfully built 92a0da91ea19這句話指明了剛剛構建的鏡像ID現在我們可以根據這個ID來進行操作。
輸入run命令來啟動。
docker run -d -p 8080:8080 92a0da91ea19
控制臺輸出:
root@izz30yg92yl9i3z /# docker run -d -p 8080:8080 92a0da91ea19 62b837ac75e3d83a4be2d7b0f6edee5ff70c69a98bac4ff74c7ed6d3e70282ee root@izz30yg92yl9i3z /#
-d 表示后臺運行
-p映射端口
已經運行成功訪問接口。注意這里因為映射到了宿主機的端口所以訪問的是宿主機的IP加端口
更多參數輸入查看:docker build --help
3.2 使用Maven構建上面說了使用Dockerfile構建,現在使用Maven來構建,
在pom中加入docker構建依賴
com.spotify docker-maven-plugin 0.4.13 ${docker.image.prefix}/${project.artifactId} /slm/ / ${project.build.directory} ${project.build.finalName}.jar
注意dockerDirectory還是要設置Dockerfile文件的路徑
把項目復制到Linux主機中,執行解壓命令
unzip boot-docker.zip cd boot-docker
執行命令:
mvn package docker:build
控制臺輸出:
[INFO] Building image boot-docker/boot-docker Step 1/7 : FROM java:8 ---> d23bdf5b1b1b Step 2/7 : EXPOSE 8080 ---> Using cache ---> b2445bf62da8 Step 3/7 : VOLUME /slm ---> Using cache ---> b73d0b73b868 Step 4/7 : ADD boot-docker-0.0.1-SNAPSHOT.jar boot-docker.jar ---> Using cache ---> 2b4868aafca9 Step 5/7 : RUN sh -c "touch /boot-docker.jar" ---> Using cache ---> 816b59f199af Step 6/7 : ENV JAVA_OPTS="" ---> Using cache ---> 784f033b9dd6 Step 7/7 : ENTRYPOINT [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /boot-docker.jar" ] ---> Using cache ---> 92a0da91ea19 ProgressMessage{id=null, status=null, stream=null, error=null, progress=null, progressDetail=null} Successfully built 92a0da91ea19 Successfully tagged boot-docker/boot-docker:latest [INFO] Built boot-docker/boot-docker [INFO] ------------------------------------------------------------------------ [INFO] BUILD SUCCESS [INFO] ------------------------------------------------------------------------ [INFO] Total time: 19.908s [INFO] Finished at: Wed Jul 10 16:00:21 CST 2019 [INFO] Final Memory: 35M/86M [INFO] ------------------------------------------------------------------------
和上面相同。啟動
歡迎轉發點贊
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/75293.html
摘要:在年下旬開源了一款新的工具,可以輕松地將應用程序容器化。由于默認訪問谷歌的倉庫,而國內訪問不穩定會經常導致網絡超時,所以筆者使用了國內的阿里云鏡像服務,那么就不需要訪問谷歌的倉庫了。執行完成后,我們可以在阿里云鏡像倉庫獲取鏡像。 原文地址:梁桂釗的博客博客地址:http://blog.720ui.com 歡迎關注公眾號:「服務端思維」。一群同頻者,一起成長,一起精進,打破認知的局限性。...
摘要:在年下旬開源了一款新的工具,可以輕松地將應用程序容器化。由于默認訪問谷歌的倉庫,而國內訪問不穩定會經常導致網絡超時,所以筆者使用了國內的阿里云鏡像服務,那么就不需要訪問谷歌的倉庫了。執行完成后,我們可以在阿里云鏡像倉庫獲取鏡像。 原文地址:梁桂釗的博客博客地址:http://blog.720ui.com 歡迎關注公眾號:「服務端思維」。一群同頻者,一起成長,一起精進,打破認知的局限性。...
摘要:市長信箱郵件查詢服務將應用部署到在上一章我完成了將部署到的工作和都具有能快速啟動的特性因此是一對用來部署微服務的黃金搭檔在計劃中基于的應用也將部署到之上那我們就開始行動吧將部署到上需要執行以下步驟保證打包后的可執行能正常啟動在應用中編寫鏡像 市長信箱郵件查詢服務: 將SpringBoot應用部署到Docker 在上一章, 我完成了將ES部署到Docker的工作. SpringBoot和...
摘要:集成上服務在我的應用中希望能使用一些的特性比如這樣的數據結構如果能方便的在開發環境中使用起來就好了如何集成呢這里依然使用和來幫忙通過使用我們就能快速的部署好服務而通過使用我們能快速的把集成進我們的服務并能使用提供的模板方法方便的調用的使用快 SpringBoot集成Docker上Redis服務 在我的應用中, 希望能使用一些redis的特性:比如zset這樣的數據結構,如果能方便的在開...
閱讀 1699·2021-11-12 10:36
閱讀 1615·2021-11-12 10:36
閱讀 3442·2021-11-02 14:46
閱讀 3798·2019-08-30 15:56
閱讀 3533·2019-08-30 15:55
閱讀 1462·2019-08-30 15:44
閱讀 1043·2019-08-30 14:00
閱讀 2735·2019-08-29 18:41