摘要:本文旨在通過將一個具體的項目進行化處理,從而對的基本用法進行一次實踐。該項目化后,后端服務訪問數據庫正常,仍然可以打開后端服務托管的單頁應用,總之項目運行狀態(tài)符合預期。
本文旨在通過將一個具體的 Spring Boot + MongoDB 項目進行 Docker 化處理,從而對 Docker 的基本用法進行一次實踐。該項目 Docker 化后,后端服務訪問數據庫正常,仍然可以打開后端服務托管的單頁 Web 應用,總之項目運行狀態(tài)符合預期。具體使用的項目見 這個 GitHub 倉庫。
學習 Docker 的基本原理、基本用法可以參考這本開源電子書《Docker — 從入門到實踐》,我覺得這本書寫的算是目前最好的了,至少比一些同類出版書刊好。
Docker 的基本原理、基本用法均不在這篇文章介紹,想學習 Docker 請參考上面這本開源書,本文進記錄一次項目的 Docker 化實踐。
1. 環(huán)境準備java: JDK 1.8
Linux: Ubuntu 17.10.1
Docker CE: 17.12.0
2. 官方 Docker 鏡像的獲取在 Docker Store 中,搜索想要獲取的 Docker 鏡像,然后按照說明獲取即可。
2.1 獲取 Java JREdocker pull store/oracle/serverjre:82.2 獲取 Java JRE
docker pull mongo3. 構建自定義 Docker 容器
Java 項目構建為 Docker 容器需要如下文件:
Jar 文件
本地配置文件
Dockerfile 文件
Dockerfile 的內容如下所示:
# 基礎 JRE 鏡像 FROM store/oracle/serverjre:8 # 修改時區(qū),使得容器時間為北京時間 RUN echo "Asia/Shanghai" > /etc/timezone # 將所需項目文件復制進入容器中 WORKDIR /app ADD ./ClusterDevicePlatform-server-1.8.9-release.jar /app ADD ./setting /app # 暴露容器的端口 EXPOSE 30232 8080 # 運行項目 CMD ["java", "-jar", "-Dfile.encoding=UTF-8", "ClusterDevicePlatform-server-1.8.9-release.jar"]
Dockerfile 文件編寫完成后,該 Java 服務器目錄下會有三個文件,其中 setting 文件和 Jar 包為原始項目的組成部分,需配套使用,setting 必須放在 Jar 包的同級目錄下,示意如下:
之后執(zhí)行如下命令:
docker build -t ky-server .
即可開始構建 Java 服務端應用的 Docker 鏡像,生成的鏡像命名為「ky-server」。
Java 服務端應用的 Docker 鏡像構建完成后,執(zhí)行 docker images 命令,即可獲取本機保存的所有 Docker 鏡像,如下所示:
4. 運行已容器化的 Java 服務端應用 4.1 創(chuàng)建 Docker Network隨著 Docker 網絡的完善,官方建議將容器加入自定義的 Docker 網絡來連接多個容器,下面先創(chuàng)建一個新的 Docker 網絡,并命名為 bitky:
docker network create -d bridge bitky
打開兩個 Shell,分別執(zhí)行如下兩條指令:
docker run --rm --name kylinked-mongo -p 27017:27017 --network bitky mongo:latest docker run --rm --name kylinked-server -p 80:8080 -p 30232:30232 --network bitky ky-server:latest
即可分別打開在兩個 Shell 前臺打開 MongoDB 和 Java 服務端應用,其中 MongoDB 容器的 27017 映射到了操作系統的同名端口,Java 服務器的 8080 端口映射到了操作系統的 80 端口,方便瀏覽器訪問。MongoDB 鏡像直接通過常規(guī)方式 pull 即可,本文不再贅述。
打開一個新的終端查看容器的狀態(tài)信息:
docker container ls
從圖中可以直觀看到端口映射狀態(tài)及容器運行狀態(tài)。
4.2 Docker 中設置時區(qū)為東八區(qū)「北京時間」容器中的默認時區(qū)是 UTC,如果要修改自制 Docker 鏡像的時區(qū),只需要在 Dockerfile 中加入下面兩句就可以了:
RUN echo "Asia/Shanghai" > /etc/timezone RUN dpkg-reconfigure -f noninteractive tzdata
需要注意的是,本文給出的 Dockerfile 已添加了如上的語句,不需要重復添加該語句。 RUN dpkg-reconfigure -f noninteractive tzdata 是 Ubuntu 修改時區(qū)的命令。如果你的自定義鏡像使用的是其他發(fā)行版,那么這里的命令也要改變。本文采用的是 JRE 作為基礎鏡像,經過實驗發(fā)現,只需要執(zhí)行指令的第一句即可。
參考鏈接Docker Documentation
Docker 部署 SpringBoot 項目整合 Redis 鏡像做訪問計數 Demo
Spring Boot 應用發(fā)布到 Docker
一步步帶你構建 Spring Boot + Docker 應用
Docker 中如何設置 container 的時區(qū)
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/19260.html
摘要:本文旨在通過將一個具體的項目進行化處理,從而對的基本用法進行一次實踐。該項目化后,后端服務訪問數據庫正常,仍然可以打開后端服務托管的單頁應用,總之項目運行狀態(tài)符合預期。 本文旨在通過將一個具體的 Spring Boot + MongoDB 項目進行 Docker 化處理,從而對 Docker 的基本用法進行一次實踐。該項目 Docker 化后,后端服務訪問數據庫正常,仍然可以打開后端服...
摘要:本文旨在通過將一個具體的項目進行化處理,從而對的基本用法進行一次實踐。該項目化后,后端服務訪問數據庫正常,仍然可以打開后端服務托管的單頁應用,總之項目運行狀態(tài)符合預期。 本文旨在通過將一個具體的 Spring Boot + MongoDB 項目進行 Docker 化處理,從而對 Docker 的基本用法進行一次實踐。該項目 Docker 化后,后端服務訪問數據庫正常,仍然可以打開后端服...
摘要:本文簡單介紹是什么,為什么用,怎么用。技術棧是什么是一個開發(fā)平臺,用于生成,開發(fā),部署和。實現需定制化源碼。 本文簡單介紹Jhipster是什么,為什么用Jhipster,怎么用Jhipster。 WHAT - 技術棧 JHipster是什么 JHipster是一個開發(fā)平臺,用于生成,開發(fā),部署Spring Boot + Angular/React Web Application和Sp...
摘要:今天整理了一下近大半年以來的一些文章,和我的預期一樣,很多文章我都忘記自己曾經寫過了,這個記錄的過程讓我也有了新的理解。希望大家,收藏,點贊,加轉發(fā)。 今天整理了一下近大半年以來的一些文章,和我的預期一樣,很多文章我都忘記自己曾經寫過了,這個記錄的過程讓我也有了新的理解。希望大家,收藏,點贊,加轉發(fā)。 面試必備 面試必備:深入Spring MVC DispatchServlet 源碼...
摘要:今天整理了一下近大半年以來的一些文章,和我的預期一樣,很多文章我都忘記自己曾經寫過了,這個記錄的過程讓我也有了新的理解。希望大家,收藏,點贊,加轉發(fā)。 今天整理了一下近大半年以來的一些文章,和我的預期一樣,很多文章我都忘記自己曾經寫過了,這個記錄的過程讓我也有了新的理解。希望大家,收藏,點贊,加轉發(fā)。 面試必備 面試必備:深入Spring MVC DispatchServlet 源碼...
閱讀 2082·2023-04-25 21:11
閱讀 2971·2021-09-30 09:47
閱讀 2283·2021-09-24 09:48
閱讀 4445·2021-08-23 09:43
閱讀 903·2019-08-30 15:54
閱讀 571·2019-08-28 18:01
閱讀 1409·2019-08-27 10:55
閱讀 595·2019-08-27 10:55