今天在学习docker的时候想着自己部署一下springboot项目,想练练手,毕竟之前都是学的理论,随后就做了一个简单的springboot 项目,打包好,然后上传至linux服务器中,然后使用自定义镜像的方式来使用docker部署,Dockerfile文件内容如下,需要注意的是,Dockerfile文件必须叫这个名字,不然会报错
FROM java:8
VOLUME /tmp
ADD docker-0.0.1-SNAPSHOT.jar docker-boot.jar
EXPOSE 8080
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/docker-boot.jar"]
然后就使用docker build -t [复制jar包的名称] 来进行镜像的制作,随后使用docker run的命令创建并且启动容器,然后使用docker ps -a的命令发现容器的状态为exited,如下图,起初也没有注意,随后才发现容器并没有启动起来。
随后就百度,结果返现导致这个错误的原因有太多了,可能的原因有如下
1.容器运行完成:当容器内的应用程序执行完毕后,容器会自动停止并进入Exited状态。
2.应用程序错误:如果容器内的应用程序出现错误或异常,容器会停止运行并进入Exited状 态。
3.容器被手动停止:通过Docker命令行工具或API,可以手动停止容器,导致容器进入Exited状态
因为原因有点多,所以最好是使用docker查询日志来判断错误类型,命令如下:
docker logs [容器id]
随后发现如下错误:
后经过百度得知原因是因为在本地windows系统下使用的java版本为17,而在Dockerfile中使用的基础镜像为java8,java版本不一致导致发生了错误。