使用Docker部署Spring Boot的方法示例
这里主要用到spring-boot开箱即用,能生成一个独立运行的程序,及maven的插件docker-maven-plugin
这里主要步骤
- 构建一个简单的springboot项目
- 添加docker-maven-plugin及写dockerfile
- 实践生成docker镜像
一个简单SpringBoot项目
以springboot2.0为例
在pom.xml文件中增加parament依赖
org.springframework.boot spring-boot-starter-parent 2.0.0.RELEASE
增加web和测试依赖
org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-starter-test test
创建一个Controller,在其中有一个index()方法,访问时返回:HelloDocker!
@RestController publicclassController{ @RequestMapping("/") publicStringindex(){ return"HelloDocker!"; } }
启动类
@SpringBootApplication publicclassApplication{ publicstaticvoidmain(String[]args){ SpringApplication.run(Application.class,args); } }
添加完毕后启动项目,启动成功后浏览器放问:http://localhost:8080/,页面返回:HelloDocker!,说明SpringBoot项目配置正常。
添加dcoker-maven-plugin
在pom.xml的properties节点中添加Docker镜像前缀
springboot
在plugins中添加docker构建插件
org.springframework.boot spring-boot-maven-plugin com.spotify docker-maven-plugin 1.0.0 ${docker.image.prefix}/${project.artifactId} src/main/docker / ${project.build.directory} ${project.build.finalNmae}.jar
编写Dockerfile
在目录src/main/docker下创建Dockerfile文件,Dockerfile文件用来说明如何来构建镜像。
FROMopenjdk:8-jdk-alpine VOLUME/tmp ADDspring-boot-docker-1.0.jarapp.jar ENTRYPOINT["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"] EXPOSE8080
这个Dockerfile文件很简单,构建Jdk基础环境,添加SpringBootJar到镜像中,简单的说明一下:
- FROM,表示使用Jdk8环境为基础镜像,如果镜像不是本地的会从DockerHub进行下载
- VOLUME,VOLUME指向了一个/tmp的目录,由于SpringBoot使用内置的Tomcat容器,Tomcat默认使用/tmp作为工作目录。这个命令的效果是:在宿主机的/var/lib/docker目录下创建一个临时文件并把它链接到容器中的/tmp目录
- ADD,拷贝文件并且重命名
- ENTRYPOINT,为了缩短Tomcat的启动时间,添加java.security.egd的系统属性指向/dev/urandom作为ENTRYPOINT
- EXPOSE指明8080端口提供服务
生成docekr镜像
需要有一个Docker环境来打包SpringBoot项目。
需要三个依赖
- jdk环境
- maven
- docker环境
运行java-version,mvn-version,dockerversion这些命令不报错就是环境准备好了。
进入项目目录
mvnpackage-Dmavne.test.skip=true java-jartarget/spring-boot-docker-1.0.jar
能正常运行,说明jar包没问题。
然后构建镜像
mvndocker:build
显示buildsuccess就成功。
使用dockerimages来查看构建好的镜像
运行镜像
dockerrun-p8080:8080-tspringboot/spring-boot-docker
然后curlhttp://127.0.0.1:8080可以看到返回HelloDocker!,说明成功
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。