![0e8f1e45522c1d793943cb634d302b6f.png](https://i-blog.csdnimg.cn/blog_migrate/b012c6613793cbde43829dc6ce6eb178.jpeg)
(1) 首先要有一个可以工作的SpringBoot应用。
从Jerry的github上clone这个github repository到本地:
![941297eff9648eefdef2a81a0b46d5f2.png](https://i-blog.csdnimg.cn/blog_migrate/48a1d693d0d0c116dc7602b422ea5275.png)
cd进入项目文件夹内,使用命令行mvn spring-boot:run
当看到控制台输出 Tomcat started on port: 5030(http)的提示后,说明SpringBoot应用在本地启动成功,
![2c8a3af2c6ad4bea134de4e3b6d29385.png](https://i-blog.csdnimg.cn/blog_migrate/a03a9816fb42ab6bdb62c0113e59be78.jpeg)
这时用下面的url可以访问这个SpringBoot应用,如果一切正常,
http://localhost:5030/commerce/product
可以在浏览器里看到Hello World:
![58915ebe630a6ce102f595d32b2332af.png](https://i-blog.csdnimg.cn/blog_migrate/f89a56c1bac66bc058ac190919bfd6b4.png)
注:该SpringBoot应用监听的端口为5030,如果想修改成其他端口,在application.properties里修改。
![321528eb123e976b57cc0d749a87f778.png](https://i-blog.csdnimg.cn/blog_migrate/41dd09350943233a170313db73e1a36d.png)
(2) 下一步是登录阿里云服务器,将该SpringBoot打包成Docker镜像。
我的github仓库里已经写好了一个Dockerfile文件,Docker镜像就是基于该Dockerfile进行制作。
![13b8a7fd8e42119d9c7bcb62878ebb70.png](https://i-blog.csdnimg.cn/blog_migrate/ba94a4688230ff3f2f9714f121ef9603.png)
第一行的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这个基础镜像:
![909cac68084b72b0d375f5ccc4dfc019.png](https://i-blog.csdnimg.cn/blog_migrate/5f7922586b9b8d9757d2ccbd47299813.png)
然后依次执行剩余步骤。
![6580c3c85e43b5036ef0f5fea5a4d524.png](https://i-blog.csdnimg.cn/blog_migrate/324b0815af8a0ad3d83bca2053f735dc.jpeg)
看到Successfully built 提示消息后,说明该镜像成功创建了。
使用docker images命令行能看到这个镜像,大小为136MB.
![566c2c8425033539c7db5db605510d3b.png](https://i-blog.csdnimg.cn/blog_migrate/51570df7d6ea04e3d05c36c93640e8b0.jpeg)
(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
![c2117cf5b3989b52df5f4282ad9e7f1d.png](https://i-blog.csdnimg.cn/blog_migrate/7540f47f5ae24ee86899cd17e9761373.png)
可以使用docker ps命令拿到该运行镜像的ID,再用docker stop命令终止镜像的运行。
也可以使用命令docker exec -it, 进入一个正在运行的容器内部:
> sudo docker exec -it 8302db78f838 /bin/sh
我们之前在编写Dockerfile时,用VOLUME指令创建的tmp,此时进入容器内部就可以观察到了。在tmp里,果然发现了SpringBoot在执行过程中,其内置的Tomcat实例运行时工作目录下生成的数据。
![e328881232ac3d5741554f6d888b7633.png](https://i-blog.csdnimg.cn/blog_migrate/b05090734b23a771a5e85e1dfc9aa08c.png)