springboot热部署

java文件编译为class文件,经过classLoader(类加载器加载成class对象),对象就会存在JVM中,所谓的调用class对象其实就是去JVM中找那个引用。

热部署就是将这个对象改了,也能让JVM动态感知道,让JVM中的对象成为一个新的对象。之前改了不起作用是因为JVM已经存在这个对象就不会再去加载更新的class文件。

java自带的类加载器
BootStrapClassLoader 隐式存在,不存在jdk里面,存在JVM里面,加载整个jdk下面的
ExtClassLoader 扩展类加载器,主要加载EXT包下面的文件
ApplicationClassLoader 加载系统上下文class文件 项目中的class文件
CustomClassLoader 自定义加载器
以上加载器是从上至下,父子关系也是,当一个类加载器去加载class文件时,并不会由自己去加载而是由父类加载器去加载,也就是双亲委派(父类委托)
同一个ClassLoader里面只会存在一个相同名字的Class文件, 本地会缓存一个class引用,这个classLoader第二次加载时候去直接去缓存找,他不会在加载一次。
同一个class文件被不同的ClassLader加载类型是不同的 例如:A a = ClassLaderA.load B a = ClassLaderB .load 如果a=b会报类型不同的错

不去重写ClassLader默认情况下每个class文件只会存在一份
这样设计保证系统里面一个class对象只会存在一份,保证系统核心class文件不被篡改(比如重写java.lang.String,equals(Systrm,exit())方法,这个如果被ApplicationClassLoader加载了整个项目就用自己写的就不对了,所以双亲委派避免了这种情况)

findLoaderClass找本地缓存引用,是一个native在这里插入图片描述
在这里插入图片描述
如果没有缓存对象他就尝试双亲委派机制,他会先去父接点找递归调用。如果没有由BootStrapClassLoader去加载
在这里插入图片描述
.热部署是有个classA文件,现在把classA中有些逻辑改了,(打破双亲委派,本地的ClassLoader不走缓存)
打破1.重写loadClass方法 2.把缓存那个方法重写了。就不会走双亲委派

全盘委托机制 用于确认默认使用的类加载器(new 关键字那个类加载器)
当有new关键字需要类加载器加载的时候 jvm会判断当前调用new关键字的类加载器是什么,然后用调用new关键字的类加载器.

springboot热部署,当监听到ClassPathChangeEvent的时候,就会重启应用把ApplicationContext close掉。并通知JVM GC和清楚对象引用,通过热部署的ClassLoader去加载ApplicationCLassLoader并且通过反射去调用程序启动

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值