天天看点

一步步把一个SpringBoot应用打包成Docker镜像并运行

1) 首先要有一个可以工作的SpringBoot应用。

从Jerry的

github

上clone这个github repository到本地:

一步步把一个SpringBoot应用打包成Docker镜像并运行

cd进入项目文件夹内,使用命令行mvn spring-boot:run

当看到控制台输出 Tomcat started on port: 5030(http)的提示后,说明SpringBoot应用在本地启动成功,

一步步把一个SpringBoot应用打包成Docker镜像并运行

这时用下面的url可以访问这个SpringBoot应用,如果一切正常,

http://localhost:5030/commerce/product

可以在浏览器里看到Hello World:

一步步把一个SpringBoot应用打包成Docker镜像并运行

祝:该SpringBoot应用监听的端口为5030,如果想修改成其他端口,在application.properties里修改。

一步步把一个SpringBoot应用打包成Docker镜像并运行

(2) 下一步是登录阿里云服务器,将该SpringBoot打包成Docker镜像。

我的github仓库里已经写好了一个Dockerfile文件,Docker镜像就是基于该Dockerfile进行制

一步步把一个SpringBoot应用打包成Docker镜像并运行

第一行的FROM命令,指定了我们这个镜像基于openjdk这个镜像制作。

第二行的VOLUME命令,定义了一个持久化存储,指向容器中的tmp文件夹。SpringBoot应用为内置的Tomcat服务器实例创建的默认工作目录为tmp,通过该命令,可以在运行Docker的宿主机目录/var/lib/docker创建一个临时的目录,挂接到容器内部的tmp去。

如果你的SpringBoot应用不会进行持久化写操作,则该步骤可以省略。

第三行,把本地目录下target文件夹里打好的jar文件添加到容器里,重命名为app.jar.

第四行:ENV命令的作用是设置环境变量。在复杂的使用场景中,我们可能需要使用各种参数启动JVM,这些参数通过ENV命令设置的环境变量传入Java命令。在这个简单的例子里可以省略环境变量的设置。

第五行:ENTRYPOINT,顾名思义,容器镜像运行的起始点。

了解了这个Dockerfile的作用和语法后,我们使用docker build基于这个Dockerfile生成一个镜像。

一步步把一个SpringBoot应用打包成Docker镜像并运行

面命令行最后的".“并不是表示结束的标点符号,而是Linux系统里的”.", 代表当前目录。

执行上述命令行后,会看到我们在Dockerfile里定义的5条命令被依次执行,首先是下载openJDK这个基础镜像:

一步步把一个SpringBoot应用打包成Docker镜像并运行

然后依次执行剩余步骤。

一步步把一个SpringBoot应用打包成Docker镜像并运行

看到Successfully built 提示消息后,说明该镜像成功创建了。

使用docker images命令行能看到这个镜像,大小为136MB.

一步步把一个SpringBoot应用打包成Docker镜像并运行

3) 最后,就是使用docker run命令执行这个镜像。

run命令有很多参数,比如以交互式方式运行镜像:

一步步把一个SpringBoot应用打包成Docker镜像并运行

这种方式下,镜像处理用户请求时的输出会自动重定向到宿主机的控制台上。

而-p参数可以实现端口映射,下面命令行的含义是把Docker内SpringBoot应用监听的端口映射到宿主机的8000端口。这样,当用户在浏览器里访问时,使用的端口应该是宿主机的端口8000.

一步步把一个SpringBoot应用打包成Docker镜像并运行

以使用docker ps命令拿到该运行镜像的ID,再用docker stop命令终止镜像的运行。

也可以使用命令docker exec -it, 进入一个正在运行的容器内部:

一步步把一个SpringBoot应用打包成Docker镜像并运行

我们之前在编写Dockerfile时,用VOLUME指令创建的tmp,此时进入容器内部就可以观察到了。在tmp里,果然发现了SpringBoot在执行过程中,其内置的Tomcat实例运行时工作目录下生成的数据。

一步步把一个SpringBoot应用打包成Docker镜像并运行