1、热部署的使用场景:线上发布、本地调试。
2、热部署的优点:
无论线上发布还是本地调试,都适用;
无需重启服务器:
——提高开发、调试效率。
——提升发布、运维效率,降低运维成本。
3、热部署和热加载的联系和区别:
联系:
——不重启服务器编译/部署项目
——基于Java的类加载器实现
区别:
从部署方式看:
——热部署在服务器运行时重新部署项目
——热加载在运行时重新加载class
从实现原理看:
——热部署直接重新加载整个应用
——热加载在运行时重新加载class
从使用场景看:
——热部署更多的是在生产环境中使用
——热加载更多的是在开发环境中使用
4、热部署原理解析
说到springboot热部署的原理,就必须得提一提java类的加载过程了。下面是一张大致的原理图:
首先呢,是先把Java文件编译为字节码文件,再把这些字节码序列化为相应的串(可以把这恶串理解为字符串),然后再把序列化之后的串编译成源码对象,再其次,把这些源码对象编译成.class文件,最后类加载器,也就是ClassLoader负责将.class文件加载到Java虚拟机中运行。
类的加载大致非为5个阶段:加载、验证、准备、解析和初始化。
加载:找到类的静态存储结构,并加载到虚拟机里面,然后转化成方法区的运行时数据结构,生成Class对象。(这个阶段,用户可以自定义加载器参与进来)
验证:确保字节码是安全的,不会对虚拟机造成危害,可以通过修改Java虚拟机的启动参数来禁用一些验证。
准备:确定内存布局,初始化类变量。这边的赋值是赋的是初始值,不会执行程序的赋值操作。
解析:是将符号引用变成直接引用。
初始化:这个阶段才是调用程序自定义的代码(,但是遇到new,getstatic,putstatic和invokestatic这4条指令时,如果类没有初始化时,必须初始化类。)
Java虚拟没有强制约束什么时候开始初始化阶段,但是以下情况必须初始化类:
(1)遇到new,getstatic,putstatic和invokestatic这4条指令。(被final修饰的静态字段除外,因为已在编译期把结果放入常量池中了)
(2)对类进行反射调用时。
(3)当初始化一个子类时,发现其父类没有初始化,则需先出发其父类的初始化。
(4)当虚拟机启动时,一个类包含main()方法时,当前类需要初始化。
(5)使用JDK1.7的动态语言时,如果一个java.lang.invoke.MethodHandle实例后解析结果REF_putStatic,REF_getStatic,REF_invokeStatic的方法句柄时,当改方法句柄对应的类没有初始化时,需要初始化该类。
Java类加载器的特点:
(1)、由AppClass Loader(系统类加载器)开始加载指定的类。
(2)、类加载器将加载任务交给其父类,如果其父类找不到,再有自己去加载。
(3)、BootStrap Loader(启动类加载器)是顶级的类加载器。
Java类的热部署:
Java类的热部署主要有两种方法:类的热加载和配置tomcat。
类的热加载:
tomcat的配置详情可查看我的另一篇博客:。
5、springboot热部署的实现
(1)在pom.xml中的plugin节点下添加配置
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>springloaded<artifactId>
<version>1.2.6.RELEASE</version>
</dependency>
</dependencies>
然后打开命令行,cd到该项目的目录下,输入mvn spring-boot:run,启动项目。
(2)通过下载好的spring loaded的jar包,先打开configuration,设置以下参数并run:
(3)通过在pom.xml中配置devtools