国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Spring Boot + MongoDB 應(yīng)用的 Docker 化實(shí)踐

yacheng / 1679人閱讀

摘要:本文旨在通過(guò)將一個(gè)具體的項(xiàng)目進(jìn)行化處理,從而對(duì)的基本用法進(jìn)行一次實(shí)踐。該項(xiàng)目化后,后端服務(wù)訪問(wèn)數(shù)據(jù)庫(kù)正常,仍然可以打開后端服務(wù)托管的單頁(yè)應(yīng)用,總之項(xiàng)目運(yùn)行狀態(tài)符合預(yù)期。

本文旨在通過(guò)將一個(gè)具體的 Spring Boot + MongoDB 項(xiàng)目進(jìn)行 Docker 化處理,從而對(duì) Docker 的基本用法進(jìn)行一次實(shí)踐。該項(xiàng)目 Docker 化后,后端服務(wù)訪問(wèn)數(shù)據(jù)庫(kù)正常,仍然可以打開后端服務(wù)托管的單頁(yè) Web 應(yīng)用,總之項(xiàng)目運(yùn)行狀態(tài)符合預(yù)期。具體使用的項(xiàng)目見(jiàn) 這個(gè) GitHub 倉(cāng)庫(kù)。

學(xué)習(xí) Docker 的基本原理、基本用法可以參考這本開源電子書《Docker — 從入門到實(shí)踐》,我覺(jué)得這本書寫的算是目前最好的了,至少比一些同類出版書刊好。

Docker 的基本原理、基本用法均不在這篇文章介紹,想學(xué)習(xí) Docker 請(qǐng)參考上面這本開源書,本文進(jìn)記錄一次項(xiàng)目的 Docker 化實(shí)踐。

1. 環(huán)境準(zhǔn)備

java: JDK 1.8

Linux: Ubuntu 17.10.1

Docker CE: 17.12.0

2. 官方 Docker 鏡像的獲取

在 Docker Store 中,搜索想要獲取的 Docker 鏡像,然后按照說(shuō)明獲取即可。

2.1 獲取 Java JRE
docker pull store/oracle/serverjre:8 
2.2 獲取 Java JRE
docker pull mongo 
3. 構(gòu)建自定義 Docker 容器

Java 項(xiàng)目構(gòu)建為 Docker 容器需要如下文件:

Jar 文件

本地配置文件

Dockerfile 文件

Dockerfile 的內(nèi)容如下所示:

# 基礎(chǔ) JRE 鏡像
FROM store/oracle/serverjre:8

# 修改時(shí)區(qū),使得容器時(shí)間為北京時(shí)間
RUN echo "Asia/Shanghai" > /etc/timezone

# 將所需項(xiàng)目文件復(fù)制進(jìn)入容器中
WORKDIR /app
ADD ./ClusterDevicePlatform-server-1.8.9-release.jar /app
ADD ./setting /app

# 暴露容器的端口
EXPOSE 30232 8080

# 運(yùn)行項(xiàng)目
CMD ["java", "-jar", "-Dfile.encoding=UTF-8", "ClusterDevicePlatform-server-1.8.9-release.jar"]

Dockerfile 文件編寫完成后,該 Java 服務(wù)器目錄下會(huì)有三個(gè)文件,其中 setting 文件和 Jar 包為原始項(xiàng)目的組成部分,需配套使用,setting 必須放在 Jar 包的同級(jí)目錄下,示意如下:

之后執(zhí)行如下命令:

docker build -t ky-server .

即可開始構(gòu)建 Java 服務(wù)端應(yīng)用的 Docker 鏡像,生成的鏡像命名為「ky-server」。

Java 服務(wù)端應(yīng)用的 Docker 鏡像構(gòu)建完成后,執(zhí)行 docker images 命令,即可獲取本機(jī)保存的所有 Docker 鏡像,如下所示:

4. 運(yùn)行已容器化的 Java 服務(wù)端應(yīng)用 4.1 創(chuàng)建 Docker Network

隨著 Docker 網(wǎng)絡(luò)的完善,官方建議將容器加入自定義的 Docker 網(wǎng)絡(luò)來(lái)連接多個(gè)容器,下面先創(chuàng)建一個(gè)新的 Docker 網(wǎng)絡(luò),并命名為 bitky

docker network create -d bridge bitky

打開兩個(gè) 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

即可分別打開在兩個(gè) Shell 前臺(tái)打開 MongoDB 和 Java 服務(wù)端應(yīng)用,其中 MongoDB 容器的 27017 映射到了操作系統(tǒng)的同名端口,Java 服務(wù)器的 8080 端口映射到了操作系統(tǒng)的 80 端口,方便瀏覽器訪問(wèn)。MongoDB 鏡像直接通過(guò)常規(guī)方式 pull 即可,本文不再贅述。

打開一個(gè)新的終端查看容器的狀態(tài)信息:

docker container ls

從圖中可以直觀看到端口映射狀態(tài)及容器運(yùn)行狀態(tài)。

4.2 Docker 中設(shè)置時(shí)區(qū)為東八區(qū)「北京時(shí)間」

容器中的默認(rèn)時(shí)區(qū)是 UTC,如果要修改自制 Docker 鏡像的時(shí)區(qū),只需要在 Dockerfile 中加入下面兩句就可以了:

RUN echo "Asia/Shanghai" > /etc/timezone
RUN dpkg-reconfigure -f noninteractive tzdata

需要注意的是,本文給出的 Dockerfile 已添加了如上的語(yǔ)句,不需要重復(fù)添加該語(yǔ)句。 RUN dpkg-reconfigure -f noninteractive tzdata 是 Ubuntu 修改時(shí)區(qū)的命令。如果你的自定義鏡像使用的是其他發(fā)行版,那么這里的命令也要改變。本文采用的是 JRE 作為基礎(chǔ)鏡像,經(jīng)過(guò)實(shí)驗(yàn)發(fā)現(xiàn),只需要執(zhí)行指令的第一句即可。

參考鏈接

Docker Documentation

Docker 部署 SpringBoot 項(xiàng)目整合 Redis 鏡像做訪問(wèn)計(jì)數(shù) Demo

Spring Boot 應(yīng)用發(fā)布到 Docker

一步步帶你構(gòu)建 Spring Boot + Docker 應(yīng)用

Docker 中如何設(shè)置 container 的時(shí)區(qū)

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://specialneedsforspecialkids.com/yun/19260.html

相關(guān)文章

  • Spring Boot + MongoDB 應(yīng)用 Docker 實(shí)踐

    摘要:本文旨在通過(guò)將一個(gè)具體的項(xiàng)目進(jìn)行化處理,從而對(duì)的基本用法進(jìn)行一次實(shí)踐。該項(xiàng)目化后,后端服務(wù)訪問(wèn)數(shù)據(jù)庫(kù)正常,仍然可以打開后端服務(wù)托管的單頁(yè)應(yīng)用,總之項(xiàng)目運(yùn)行狀態(tài)符合預(yù)期。 本文旨在通過(guò)將一個(gè)具體的 Spring Boot + MongoDB 項(xiàng)目進(jìn)行 Docker 化處理,從而對(duì) Docker 的基本用法進(jìn)行一次實(shí)踐。該項(xiàng)目 Docker 化后,后端服務(wù)訪問(wèn)數(shù)據(jù)庫(kù)正常,仍然可以打開后端服...

    546669204 評(píng)論0 收藏0
  • Spring Boot + MongoDB 應(yīng)用 Docker 實(shí)踐

    摘要:本文旨在通過(guò)將一個(gè)具體的項(xiàng)目進(jìn)行化處理,從而對(duì)的基本用法進(jìn)行一次實(shí)踐。該項(xiàng)目化后,后端服務(wù)訪問(wèn)數(shù)據(jù)庫(kù)正常,仍然可以打開后端服務(wù)托管的單頁(yè)應(yīng)用,總之項(xiàng)目運(yùn)行狀態(tài)符合預(yù)期。 本文旨在通過(guò)將一個(gè)具體的 Spring Boot + MongoDB 項(xiàng)目進(jìn)行 Docker 化處理,從而對(duì) Docker 的基本用法進(jìn)行一次實(shí)踐。該項(xiàng)目 Docker 化后,后端服務(wù)訪問(wèn)數(shù)據(jù)庫(kù)正常,仍然可以打開后端服...

    Caizhenhao 評(píng)論0 收藏0
  • JHipster技術(shù)簡(jiǎn)介

    摘要:本文簡(jiǎn)單介紹是什么,為什么用,怎么用。技術(shù)棧是什么是一個(gè)開發(fā)平臺(tái),用于生成,開發(fā),部署和。實(shí)現(xiàn)需定制化源碼。 本文簡(jiǎn)單介紹Jhipster是什么,為什么用Jhipster,怎么用Jhipster。 WHAT - 技術(shù)棧 JHipster是什么 JHipster是一個(gè)開發(fā)平臺(tái),用于生成,開發(fā),部署Spring Boot + Angular/React Web Application和Sp...

    hightopo 評(píng)論0 收藏0
  • 墻裂推薦:搜云庫(kù)技術(shù)團(tuán)隊(duì),面試必備技術(shù)干貨

    摘要:今天整理了一下近大半年以來(lái)的一些文章,和我的預(yù)期一樣,很多文章我都忘記自己曾經(jīng)寫過(guò)了,這個(gè)記錄的過(guò)程讓我也有了新的理解。希望大家,收藏,點(diǎn)贊,加轉(zhuǎn)發(fā)。 今天整理了一下近大半年以來(lái)的一些文章,和我的預(yù)期一樣,很多文章我都忘記自己曾經(jīng)寫過(guò)了,這個(gè)記錄的過(guò)程讓我也有了新的理解。希望大家,收藏,點(diǎn)贊,加轉(zhuǎn)發(fā)。 面試必備 面試必備:深入Spring MVC DispatchServlet 源碼...

    SegmentFault 評(píng)論0 收藏0
  • 墻裂推薦:搜云庫(kù)技術(shù)團(tuán)隊(duì),面試必備技術(shù)干貨

    摘要:今天整理了一下近大半年以來(lái)的一些文章,和我的預(yù)期一樣,很多文章我都忘記自己曾經(jīng)寫過(guò)了,這個(gè)記錄的過(guò)程讓我也有了新的理解。希望大家,收藏,點(diǎn)贊,加轉(zhuǎn)發(fā)。 今天整理了一下近大半年以來(lái)的一些文章,和我的預(yù)期一樣,很多文章我都忘記自己曾經(jīng)寫過(guò)了,這個(gè)記錄的過(guò)程讓我也有了新的理解。希望大家,收藏,點(diǎn)贊,加轉(zhuǎn)發(fā)。 面試必備 面試必備:深入Spring MVC DispatchServlet 源碼...

    Neilyo 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<