Docker 应用

应用Docker部署

在项目的根目录下建立一个Dockerfile文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
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 镜像

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

从镜像启动容器

1
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 文件

1
2
3
4
5
6
7
8
9
10
11
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