SpringCloud教程 | 第十一篇: docker部署spring cloud項目

 

目錄(?)[+]java

 

轉載請標明出處: 
http://blog.csdn.net/forezp/article/details/70198649 
本文出自方誌朋的博客linux

1、docker簡介

Docker是一個開源的引擎,能夠輕鬆的爲任何應用建立一個輕量級的、可移植的、自給自足的容器。開發者在筆記本上編譯測試經過的容器能夠批量地在生產環境中部署,包括VMs(虛擬機)、bare metal、OpenStack 集羣和其餘的基礎應用平臺。 
Docker一般用於以下場景:git

  • web應用的自動化打包和發佈;
  • 自動化測試和持續集成、發佈;
  • 在服務型環境中部署和調整數據庫或其餘的後臺應用;
  • 從頭編譯或者擴展示有的OpenShift或Cloud Foundry平臺來搭建本身的PaaS環境。

Docker 的優勢github

  • 一、簡化程序: 
    Docker 讓開發者能夠打包他們的應用以及依賴包到一個可移植的容器中,而後發佈到任何流行的 Linux 機器上,即可以實現虛擬化。Docker改變了虛擬化的方式,使開發者能夠直接將本身的成果放入Docker中進行管理。方便快捷已是 Docker的最大優點,過去須要用數天乃至數週的 任務,在Docker容器的處理下,只須要數秒就能完成。web

  • 二、避免選擇恐懼症: 
    若是你有選擇恐懼症,仍是資深患者。Docker 幫你 打包你的糾結!好比 Docker 鏡像;Docker 鏡像中包含了運行環境和配置,因此 Docker 能夠簡化部署多種應用實例工做。好比 Web 應用、後臺應用、數據庫應用、大數據應用好比 Hadoop 集羣、消息隊列等等均可以打包成一個鏡像部署。spring

  • 三、節省開支: 
    一方面,雲計算時代到來,使開發者沒必要爲了追求效果而配置高額的硬件,Docker 改變了高性能必然高價格的思惟定勢。Docker 與雲的結合,讓雲空間獲得更充分的利用。不只解決了硬件管理的問題,也改變了虛擬化的方式。docker

上面文字參考了相關文章;另,關於docker 的安裝和基本的使用見相關教程數據庫

2、準備工做

環境條件:windows

  • linux系統,不建議windows
  • docker最新版本
  • jdk 1.8
  • maven3.0

本文采用的工程來自第一篇文章的工程,採用maven的方式去構建項目,並採用docker-maven-plugin去構建docker鏡像。

3、改造工程、構建鏡像

改造eureka-server工程

在pom文件加上插件:

<build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> <!-- tag::plugin[] --> <plugin> <groupId>com.spotify</groupId> <artifactId>docker-maven-plugin</artifactId> <version>0.4.3</version> <configuration> <imageName>${docker.image.prefix}/${project.artifactId}</imageName> <dockerDirectory>src/main/docker</dockerDirectory> <resources> <resource> <targetPath>/</targetPath> <directory>${project.build.directory}</directory> <include>${project.build.finalName}.jar</include> </resource> </resources> </configuration> </plugin> <!-- end::plugin[] --> </plugins> </build> 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27

Spotify 的 docker-maven-plugin 插件是用maven插件方式構建docker鏡像的。

  • imageName指定了鏡像的名字,本例爲 forep/eureka-server
  • dockerDirectory指定 Dockerfile 的位置
  • resources是指那些須要和 Dockerfile 放在一塊兒,在構建鏡像時使用的文件,通常應用 jar 包須要歸入。

修改下配置文件:

server: port: 8761 eureka: instance: prefer-ip-address: true client: registerWithEureka: false fetchRegistry: false 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

編寫dockerfile文件:

FROM frolvlad/alpine-oraclejdk8:slim VOLUME /tmp ADD eureka-server-0.0.1-SNAPSHOT.jar app.jar #RUN bash -c 'touch /app.jar' ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"] EXPOSE 8761 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

docker file編寫指令:

  • FROM
FROM <image> FROM <image>:<tag> FROM <image> <digest> 
  • 1
  • 2
  • 3
  • 4

FROM指令必須指定且須要在Dockerfile其餘指令的前面,指定的基礎image能夠是官方遠程倉庫中的,也能夠位於本地倉庫。後續的指令都依賴於該指令指定的image。當在同一個Dockerfile中創建多個鏡像時,可使用多個FROM指令。

  • VOLUME

格式爲:

VOLUME ["/data"]
  • 1

使容器中的一個目錄具備持久化存儲數據的功能,該目錄能夠被容器自己使用,也能夠共享給其餘容器。當容器中的應用有持久化數據的需求時能夠在Dockerfile中使用該指令。

  • ADD

從src目錄複製文件到容器的dest。其中src能夠是Dockerfile所在目錄的相對路徑,也能夠是一個URL,還能夠是一個壓縮包

  • ENTRYPOINT

指定Docker容器啓動時執行的命令,能夠屢次設置,可是隻有最後一個有效。

  • EXPOSE

爲Docker容器設置對外的端口號。在啓動時,可使用-p選項或者-P選項。

構建鏡像

執行構建docker鏡像maven命令:

mvn clean
mvn package docker:build 
  • 1
  • 2
  • 3

Paste_Image.png

構建eureka-server鏡像成功。

同理構建service-hi鏡像

  • pom文件導入同eurek-server
  • 修改下配置文件:
eureka: client: serviceUrl: defaultZone: http://eureka-server:8761/eureka/ # 這個須要改成eureka-server server: port: 8763 spring: application: name: service-hi 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

在這裏說下:defaultZone發現服務的host改成鏡像名。

  • dockefile 編寫同eureka-server

  • 構建鏡像:

mvn clean
mvn package docker:build 
  • 1
  • 2
  • 3

Paste_Image.png

這時咱們運行docke的eureka-server 和service-hi鏡像:

docker run -p 8761: 8761 -t forezp/eureka-server docker run -p 8763: 8763 -t forezp/service-hi 
  • 1
  • 2
  • 3

訪問localhost:8761

Paste_Image.png

4、採用docker-compose啓動鏡像

Compose 是一個用於定義和運行多容器的Docker應用的工具。使用Compose,你能夠在一個配置文件(yaml格式)中配置你應用的服務,而後使用一個命令,便可建立並啓動配置中引用的全部服務。下面咱們進入Compose的實戰吧。

採用docker-compose的方式編排鏡像,啓動鏡像:

version: '3' services: eureka-server: image: forezp/eureka-server restart: always ports: - 8761:8761 service-hi: image: forezp/service-hi restart: always ports: - 8763:8763
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

輸入命令: docker-compose up

Paste_Image.png

發現2個鏡像按照指定的順序啓動了。

源碼下載:https://github.com/forezp/SpringCloudLearning/tree/master/chapter11

5、採用docker-compose編排並啓動鏡像

docker-compose也能夠構建鏡像,如今咱們採用docker-compose的方式構建鏡像。

如今以eureka-server爲例: 
將Dockerfile移到eureka-server的主目錄,改寫ADD的相對路徑:

FROM frolvlad/alpine-oraclejdk8:slim VOLUME /tmp ADD ./target/eureka-server-0.0.1-SNAPSHOT.jar app.jar #RUN bash -c 'touch /app.jar' ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"] EXPOSE 8761
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

同理修改service-hi目錄;

編寫構建鏡像docker-compose-dev文件:

version: '3' services: eureka-server: build: eureka-server ports: - 8761:8761 service-hi: build: service-hi ports: - 8763:8763 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13

命令構建鏡像並啓動:

docker-compose -f docker-compose.yml -f docker-compose-dev.yml up 
  • 1
  • 2

Paste_Image.png

相關文章
相關標籤/搜索