在Docker中部署Spring Boot项目
在Docker中部署Spring Boot项目
微服务现在在互联网公司可谓非常流行了,之前找工作的的时候很多HR电话约面试的时候都会问对微服务是否有过接触。而微服务和Docker可以非常完美的结合,更加方便的实现微服务架构的落地。作为微服务中的代表SpringBoot框架,今天我们就来了解一下如何在Docker容器中运行一个SpringBoot应用。
创建Spring Boot程序
在这篇文章中我们将在Docker容器中运行一个简单的SpringBoot的Web应用,下面是初始时刻的pom.xml中的内容。
<?xml version="1.0" encoding="UTF-8"?>
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>cn.itweknow</groupId> <artifactId>springboot-docker</artifactId> <version>0.0.1-SNAPSHOT</version> <packaging>jar</packaging> <name>springboot-docker</name> <description>Demo project for Spring Boot</description> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.1.0.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <java.version>1.8</java.version> </properties> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build>
添加一个HelloController.java
@RestController
public class HelloController {
@RequestMapping("/hello") public String hello() { return "Hello Docker."; }
}
好了,到现在为止我们一个简单的web应用就已经建好了,可以在本地运行起来并看下效果,确保程序正确。
配置Docker
docker提供了maven构建的插件docker-maven-plugin,我们只需要在我们的pom.xml中添加这个插件,然后做相关的一些简单的配置就OK了。
<groupId>com.spotify</groupId> <artifactId>docker-maven-plugin</artifactId> <version>1.2.0</version> <configuration> <!-- 这里是最终生成的docker镜像名称 --> <imageName>itweknow/${project.artifactId}</imageName> <!-- 基础镜像,运行一个springboot应用只需要基础的java环境就行 --> <baseImage>java:8</baseImage> <!-- docker启动的时候执行的命令 --> <entryPoint>["java", "-jar", "/${project.build.finalName}.jar"]</entryPoint> <resources> <resource> <targetPath>/</targetPath> <directory>${project.build.directory}</directory> <include>${project.build.finalName}.jar</include> </resource> </resources> </configuration>
没错就这么简单,到目前我们整个项目已经搭建好了,剩下的工作就是讲项目copy到我们linux环境下生成docker镜像然后运行起来了。
构建镜像
copy项目到linux下后,进入到项目目录下,顺序执行下面的命令,就可以生成一个docker镜像了。
mvn clean
-Dmaven.test.skip=true 是跳过测试代码
mvn package -Dmaven.test.skip=true
mvn docker:build
当然你也可以三条命令一起执行
mvn clean package docker:build -Dmaven.test.skip=true
然后在执行docker images查看系统中的docker镜像,看是否生成成功。
REPOSITORY TAG IMAGE ID CREATED SIZE
itweknow/springboot-docker latest f03b689cfc33 10 seconds ago 660MB
运行Docker容器
-d 是指定后台运行
--name是指定容器名称
-p 8080:8080 是指将容器的8080端口映射给宿主机的8080端口 格式为:主机(宿主)端口:容器端口
docker run -d --name test -p 8080:8080 itweknow/springboot-docker
执行docker ps查看一下正在运行的容器
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
652fd3ccac89 itweknow/springboot-docker "java -jar /springbo…" 3 seconds ago Up 2 seconds 0.0.0.0:8080->8080/tcp test
我们的项目已经成功运行在了docker容器中了,我们可以访问一下http://虚拟机IP:8080/hello测试一下了。
总结语
本文只是简单的介绍了一下如何利用Docker部署我们的Spring Boot项目,有关Docker的内容,后面的文章我们会慢慢和大家一起了解。本文的完整实现你可以在Github上找到。
原文地址https://www.cnblogs.com/endless-code/p/11285839.html

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
docker挂载volume的用户权限问题,理解docker容器的uid
docker挂载volume的用户权限问题,理解docker容器的uid目录遇到的问题原因容器共享宿主机的uid如果不指定user,容器内部默认使用root用户来运行容器内部用户的权限与外部用户相同一定要确保容器执行者的权限和挂载数据卷对应一个更加明显的demo参考docker挂载volume的用户权限问题,理解docker容器的uid 在刚开始使用docker volume挂载数据卷的时候,经常出现没有权限的问题。这里通过遇到的问题来理解docker容器用户uid的使用,以及了解容器内外uid的映射关系。 遇到的问题本地有一个node的项目需要编译,采用docker来run npm install. sudo docker run -it --rm --name ryan \-v pwd:pwd \-w pwd node npm install --registry=https://registry.npm.taobao.org 可以看到,install之后,node_modules文件的权限变成root了。那么,作为使用者的我们就没有权限去删除这个文件了。 为什么docker输出的...
- 下一篇
阿里云Kubernetes CSI实践 - 云盘数据卷扩容
数据卷扩容 使用云盘存储卷,往往在服务初始化的时候申请了一个适当容量的云盘,但是随着数据的增长,数据盘的容量不能满足需求,需要扩容。 传统应用的扩容场景中,往往是先手动停掉应用,再对数据盘进行备份,然后执行扩容操作,最后重新启动应用。 Kubernetes本身是一个自动化调度、编排系统,实现了对数据卷的生命周期管理。最新版本中已经提供对数据卷扩容的功能;下面是一些介绍: https://kubernetes.io/blog/2018/08/02/dynamically-expand-volume-with-csi-and-kubernetes/ 数据卷扩容目前支持以下类型: gcePersistentDisk awsElasticBlockStore OpenStack Cinder glusterfs rbd csi CSI数据卷扩容目前属于
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- SpringBoot2整合Redis,开启缓存,提高访问速度
- CentOS7,CentOS8安装Elasticsearch6.8.6
- CentOS7安装Docker,走上虚拟化容器引擎之路
- Docker安装Oracle12C,快速搭建Oracle学习环境
- Linux系统CentOS6、CentOS7手动修改IP地址
- CentOS7设置SWAP分区,小内存服务器的救世主
- CentOS6,7,8上安装Nginx,支持https2.0的开启
- MySQL8.0.19开启GTID主从同步CentOS8