分享

基于Spring Boot和Spring Cloud实现微服务架构学习(六)

 Bladexu的文库 2016-11-13

应用Docker部署

下面就介绍如何将之前的Spring Boot项目部署在Docker上,首先,在应用根目录下建立 Dockerfile 文件,以使用 Maven 构建为例,选用 maven:3.3.3 官方镜像,官方维护的 Maven 镜像依赖于 Java 镜像构建,所以我们不需要使用 Java 镜像,具体内容如下:

FROM maven:3.3.3

ADD pom.xml /tmp/build/
RUN cd /tmp/build && mvn -q dependency:resolve

ADD src /tmp/build/src
        #构建应用
RUN cd /tmp/build && mvn -q -DskipTests=true package         #拷贝编译结果到指定目录
        && mv target/*.jar /app.jar         #清理编译痕迹
        && cd / && rm -rf /tmp/build

VOLUME /tmp
EXPOSE 8080
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]

  • 因为 Spring Boot 框架打包的应用是一个包含依赖的 jar 文件,内嵌了 Tomcat 和 Jetty 支持,所以我们只需要使用包含 Java 的 Maven 镜像即可,不需要 Tomcat 镜像。
  • 为了减少镜像大小,在执行 Maven 构建之后,清理了构建痕迹。
  • 在 Dockerfile 文件的最后,使用 ENTRYPOINT 指令执行启动 Java 应用的操作。

构建 Docker 镜像:

docker build -t docker-demo-spring-boot .   //注意后面的 . 表示当前路径下

从镜像启动容器:

docker run -d -p 8080:8080 docker-demo-spring-boot

完成部署:

URL访问,可通过docker ip查看应用的虚拟地址。

Docker Compose编排

Docker Compose是用于定义和组装运行多容器分布式应用的工具,它提供一个简单的基于YAML语言的docker-compose.yml配置文件。 通常,我们使用docker定义和运行复杂的应用,使用docker compose,在一个文件里定义多容器应用的启动顺序,起到服务编排的作用。

编写 docker-compose.yaml 文件

web:
  build: .
  ports:
    - "8080:8080"
  links:
    - mongodb:mongodb

mongodb:
  image: daocloud.io/library/mongo:latest
  ports:
    - "27017:27017"
这里以MongoDB数据库提供服务的demo,在该文件中,我们定于了两个服务:

  • 基于我们应用构建的 docker-demo-java-mongo 镜像,用来提供 Web 服务
  • 基于 DaoCloud 提供的 MongoDB 镜像,提供存储服务
  • 通过 links 为 web 关联 mongo 服务

启动 Docker Compose

docker-compose up

浏览器访问

以web应用为访问路径,数据将关联存储到MongoDB上。



    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多