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

简介:

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

从Jerry的github上clone这个github repository到本地:

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

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

这时用下面的url可以访问这个SpringBoot应用,如果一切正常,
http://localhost:5030/commerce/product

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

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

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

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

第一行的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生成一个镜像。

docker build -t jerry/springbootexample:v1 .

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

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

然后依次执行剩余步骤。

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

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

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

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

docker run -it jerry/springbootexample:v1

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

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

docker run -p 8000:9000 --name jerrydockerdemo -d jerry/springbootexample:v1

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

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

sudo docker exec -it 8302db78f838 /bin/sh

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

本文来自云栖社区合作伙伴“汪子熙”,了解相关信息可以关注微信公众号"汪子熙"。

相关文章
|
1月前
|
前端开发 关系型数据库 MySQL
IDEA集成Docker插件打包服务镜像与运行【附Docker命令汇总】
IDEA集成Docker插件打包服务镜像与运行【附Docker命令汇总】
|
18天前
|
Linux Docker 容器
Linux彻底卸载Docker包括运行拉取的镜像
Linux彻底卸载Docker包括运行拉取的镜像
22 1
|
25天前
|
Java 关系型数据库 数据库
Seata常见问题之docker运行报错如何解决
Seata 是一个开源的分布式事务解决方案,旨在提供高效且简单的事务协调机制,以解决微服务架构下跨服务调用(分布式场景)的一致性问题。以下是Seata常见问题的一个合集
98 0
|
25天前
|
Nacos 数据库 Docker
nacos常见问题之docker部署的seata,成功注册到nacos运行报错如何解决
Nacos是阿里云开源的服务发现和配置管理平台,用于构建动态微服务应用架构;本汇总针对Nacos在实际应用中用户常遇到的问题进行了归纳和解答,旨在帮助开发者和运维人员高效解决使用Nacos时的各类疑难杂症。
36 2
|
30天前
|
NoSQL Java Redis
利用Docker部署一个简单的springboot项目
利用Docker部署一个简单的springboot项目
69 2
|
30天前
|
JavaScript Java jenkins
如何利用CentOS7+docker+jenkins+gitee部署springboot+vue前后端项目(保姆教程)
如何利用CentOS7+docker+jenkins+gitee部署springboot+vue前后端项目(保姆教程)
78 0
|
1月前
|
JavaScript Shell Docker
|
1月前
|
Kubernetes Go 开发者
Go语言与Docker容器结合的实践应用与案例分析
【2月更文挑战第23天】本文通过分析实际案例,探讨了Go语言与Docker容器技术结合的实践应用。通过详细阐述Go语言在容器化环境中的开发优势,以及Docker容器技术在Go应用部署中的重要作用,本文旨在为读者提供Go语言与Docker容器结合的具体实现方法和实际应用场景。
|
6月前
|
存储 分布式计算 Hadoop
基于docker的Hadoop环境搭建与应用实践(脚本部署)
本文介绍了Hadoop环境的搭建与应用实践。对Hadoop的概念和原理进行了简要说明,包括HDFS分布式文件系统和MapReduce计算模型等,主要通过脚本的方式进行快捷部署,在部署完成后对HDFS和mapreduce进行了测试,确保其功能正常。
|
JavaScript Linux 应用服务中间件
Docker部署Node应用简单实践
本文将从零至一,介绍如何在云服务器上通过 Docker 容器运行一个简单的Node应用。
1217 0