Docker 实战教程之从入门到提高 (七)

本教程的前六篇文章:

以及通过这篇文章的介绍,我们深入学习了 Docker 技术的三大要点。

从本文开始,我们将学习如何将 Docker 镜像部署到云平台上并运行。

练习1:将 SpringBoot 应用 Docker 化

首先需要把 SpringBoot 应用打包成 docker,我用的 dockerfile 内容为:

FROM openjdk:8-jdk-alpine
VOLUME /tmp
VOLUME /log
EXPOSE 8080
ADD target/prolikeService.jar app.jar
ENV JAVA_OPTS="-Dserver.port=8080"
ENTRYPOINT exec java $JAVA_OPTS -jar /app.jar

使用如下的命令行打包:

docker build -t i042416/springbootexample:v4 .

docker login 登录 docker hub,将该镜像上传:

docker push i042416/springbootexample:v4
最后使用命令部署到 Cloud Platform上:

cf push jerryjavadocker --docker-image i042416/springbootexample:v4

Docker 实战教程之从入门到提高 (七)_第1张图片
Docker 实战教程之从入门到提高 (七)_第2张图片
Docker 实战教程之从入门到提高 (七)_第3张图片

命令执行完毕后,能够在 SAP 云平台的控制台里,看到这个成功部署的 Docker 应用:

Docker 实战教程之从入门到提高 (七)_第4张图片

从控制台里得到应用 url:

Docker 实战教程之从入门到提高 (七)_第5张图片

可以在浏览器里成功访问:

Docker 实战教程之从入门到提高 (七)_第6张图片

练习2:部署 Docker 镜像到 Cloud Platform 可能遇到的错误消息和解决方案

第一次尝试时,我遇到了下图的错误消息:

You have exceeded your organization's memory limit: app requested more memory than available
FAILED

Docker 实战教程之从入门到提高 (七)_第7张图片

要解决该错误,增大该 Subaccoun t的 memory quota 即可:

Docker 实战教程之从入门到提高 (七)_第8张图片

第二次尝试遇到的错误消息:

Failed getting docker image manifest by tag: errors:
denied: requested access to the resource is denied
unauthorized: authentication required

Docker 实战教程之从入门到提高 (七)_第9张图片
Docker 实战教程之从入门到提高 (七)_第10张图片

登录 docker hub,确认使用的 docker 镜像和 tag 是否正确:

https://hub.docker.com/reposi...

Docker 实战教程之从入门到提高 (七)_第11张图片

最后成功部署:

Docker 实战教程之从入门到提高 (七)_第12张图片
Docker 实战教程之从入门到提高 (七)_第13张图片

在 SAP 云平台上看到成功部署的 Docker 应用:

Docker 实战教程之从入门到提高 (七)_第14张图片

拿到应用的 url:

Docker 实战教程之从入门到提高 (七)_第15张图片

可以成功访问了:

Docker 实战教程之从入门到提高 (七)_第16张图片
Docker 实战教程之从入门到提高 (七)_第17张图片

练习3:将包含 SpringBoot 应用的 Docker 镜像部署到 CloudFoundry 环境并成功运行

容器技术,Docker,虚拟化,这些名词诞生尽管有很长一段时间了,但是在云原生开发领域仍旧热度不减。甚至连 SAP 赖以成名的 ABAP Netweaver,如今也踏上了容器化的上云探索之路,比如下面这张来自 SAP 社区的一篇博客:
Proof of Concept: Deploying ABAP in Kubernetes

Docker 实战教程之从入门到提高 (七)_第18张图片

如果有一个已经能够正常运行的 Java 应用,可以将其以 Docker 容器的方式,部署且运行在 SAP 云平台 CloudFoundry 环境上吗?当然可以,而且只需要简单的几个命令行即可。

通过本步骤的实战演练,可以了解将 Java 应用容器化并部署到 SAP 云平台 CloudFoundry 环境运行的大致步骤。您也可以根据本文的步骤动手试一试,只需要在本地搭一个最简单的 Java 开发环境,安装 Docker 客户端和申请一个 SAP 云平台的 trial 账号即可。

(1) 首先得有一个能在本地正常运行的 SpringBoot 应用。

本地配置好 maven 和 JDK 之后,直接用命令行启动它:

mvn spring-boot:run
你会看到 Tomcat started on port 8000 的提示,意思是该应用已经成功启动,监听在本地端口 8000 上。

Docker 实战教程之从入门到提高 (七)_第19张图片

浏览器里输入 localhost:8000/product, 看到 Hello World. 至此,我们就有了一个本地正常运行的 SpringBoot 应用了,下一步是将其打包成 Docker 镜像。

Docker 实战教程之从入门到提高 (七)_第20张图片

(2) 在 SpringBoot 项目里新建一个名叫 Dockerfile 的文件,输入以下内容:

FROM openjdk:8-jdk-alpine
VOLUME /tmp
VOLUME /log
EXPOSE 8080
ADD target/prolikeService.jar app.jar
ENV JAVA_OPTS="-Dserver.port=8080"
ENTRYPOINT exec java $JAVA_OPTS -jar /app.jar

Docker 实战教程之从入门到提高 (七)_第21张图片

这实际是一个指令文件,Docker 客户端会根据里面的内容,制作一个 Docker 镜像。

简要介绍每一行内容的含义。
第一行:指定待制作的镜像是基于名叫 openjdk:8-jdk-alpine 的镜像,在 Docker Hub 网站上能找到更多关于该镜像的说明。

Docker 实战教程之从入门到提高 (七)_第22张图片

第二行和第三行:定义两个名叫 tmp 和 log 的持久化存储。容器运行时产生的数据,随着容器的销毁而销毁,但有时我们又希望这些数据能够持久化保存,比如需要分析某个容器运行时产生的日志文件,这时可以使用 Dockerfile 里 VOLUME关键字提供的容器持久化技术,创建所谓的“卷”,将容器应用运行时写入数据的目录,映射到宿主机上的某个目录下。

如果一个容器尚处在运行状态,我们可以用命令行进入容器内部,查看 log 文件夹里的运行日志文件:

docker exec -it 8302db78f838 /bin/sh

Docker 实战教程之从入门到提高 (七)_第23张图片

如果该容器已经销毁,我们就可以到宿主机的 /var/lib/docker/volumes 目录下,查看持久化的日志文件:

Docker 实战教程之从入门到提高 (七)_第24张图片

第五行:把当前项目通过 maven 打包而成的 jar 包拷贝到容器内部,重命名为 app.jar

第六~七行:设置 JVM 启动参数,暴露 8080 端口给外部。

Dockerfile 文件编写完毕后,使用命令行制作镜像:

docker build -t i042416/springbootexample:v1 .

v1 代表该镜像的标签,命令行尾部的句号代表当前目录。

镜像制作完毕后,使用命令行将制作好的镜像推送到 Docker Hub 网站上(有点像我们本地用 git 客户端提交代码到 Github上):

docker push i042416/springbootexample:v1
成功之后,能够在 Docker Hub 上看到推送好的镜像:

https://hub.docker.com/reposi...

Docker 实战教程之从入门到提高 (七)_第25张图片

这样,稍后 SAP 云平台就能从 Docker Hub 上拉取这个镜像了。

(3) 登录 SAP 云平台 CloudFoundry 环境,使用命令行部署, 用参数 --docker-image 指定我们刚刚上传到 Docker Hub 上的镜像名称,部署生成的应用名叫 jerryjavadocker.

cf push jerryjavadocker --docker-image i042416/springbootexample:v6
因为我的容器镜像修改过好几次,所以标签从 v1 升到了 v6.

Docker 实战教程之从入门到提高 (七)_第26张图片

成功部署,应用的状态显示成了 running:

Docker 实战教程之从入门到提高 (七)_第27张图片

在 SAP 云平台 CloudFoundry 环境也能看到这个成功部署的应用,处于运行状态:

Docker 实战教程之从入门到提高 (七)_第28张图片

运行这个成功部署好的 Docker 应用,和我们在本地 mvn spring-boot:run 的效果一样。至此这个 SpringBoot 应用的容器化和 SAP 云平台 CloudFoundry 环境的部署就成功了。

Docker 实战教程之从入门到提高 (七)_第29张图片

总结

本文回顾了本教程前一步骤如何将 SpringBoot 应用制作成 Docker 镜像的过程,然后介绍了如何将 Docker 镜像部署到云平台 CloudFoundry 环境并运行的详细步骤,并针对部署过程中的常见错误消息,给出了对应的错误分析和解决方案。

本系列前六篇文章:

你可能感兴趣的:(Docker 实战教程之从入门到提高 (七))