首页 > 其他分享 >spring-boot-devtools 使用方式

spring-boot-devtools 使用方式

时间:2023-03-01 23:14:20浏览次数:55  
标签:03 01 spring boot --- 2023 devtools

spring-boot-devtools

随着项目的规模扩大,为了解决项目在修改代码后的重启时间过长的问题,在项目中引入了 spring-boot-devtools。

在典型的应用程序开发场景中,开发人员会进行一些更改,然后重新构建项目并启动应用程序以使新更改生效,
spring-boot-devtools 可以让开发人员在修改代码后,无需手动重新启动应用,由该工具自动重新启动应用。

实践

添加如下 Maven 依赖:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-devtools</artifactId>
</dependency>

使用IDE 以 --debug 参数启动应用,可以看到如下日志:

20:13:32.110 [Thread-0] DEBUG org.springframework.boot.devtools.restart.classloader.RestartClassLoader - Created RestartClassLoader org.springframework.boot.devtools.restart.classloader.RestartClassLoader@5ed2f852

  .   ____          ___ _ _
 /\\ / ___'_ __ _ _(_)_ __  __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
 \\/  ___)| |_)| | | | | || (_| |  ) ) ) )
  '  |____| .__|_| |_|_| |_\__, | / / / /
 =========|_|==============|___/=/_/_/_/
 :: Spring Boot ::    (v2.7.9)

2023-03-01 20:13:32.970 DEBUG 5868 --- [  restartedMain] o.s.b.devtools.restart.ChangeableUrls    : Matching URLs for reloading : [file:/D:/code/spring/test/target/classes/]
2023-03-01 20:13:32.971 DEBUG 5868 --- [  restartedMain] o.s.b.d.settings.DevToolsSettings        : Included patterns for restart : []
2023-03-01 20:13:32.971 DEBUG 5868 --- [  restartedMain] o.s.b.d.settings.DevToolsSettings        : Excluded patterns for restart : [/spring-boot-starter-[\w-]+/, /spring-boot/(bin|build|out)/, /spring-boot-starter/(bin|build|out)/, /spring-boot-devtools/(bin|build|out)/, /spring-boot-actuator/(bin|build|out)/, /spring-boot-autoconfigure/(bin|build|out)/]
2023-03-01 20:13:36.520  INFO 5868 --- [  restartedMain] tk.lsq27.test.TestApplication: Started TestApplication in 4.395 seconds (JVM running for 5.208)
2023-03-01 20:13:36.527 DEBUG 5868 --- [  restartedMain] o.s.boot.devtools.restart.Restarter      : Creating new Restarter for thread Thread[main,5,main]
2023-03-01 20:13:36.527 DEBUG 5868 --- [  restartedMain] o.s.boot.devtools.restart.Restarter      : Immediately restarting application
2023-03-01 20:13:36.527 DEBUG 5868 --- [  restartedMain] o.s.boot.devtools.restart.Restarter      : Starting application tk.lsq27.test.TestApplication with URLs [file:/D:/code/spring/test/target/classes/]

如日志所示,应用程序所在的线程不是 main 线程,而是 restartedMain 线程。项目中所做的任何更改,都将导致项目自动重新启动。
修改 TestApplication.java 并保存,触发该文件重新编译,产生日志如下:

2023-03-01 20:15:26.600  INFO 5868 --- [   File Watcher] rtingClassPathChangeChangedEventListener : Restarting due to 1 class path change (0 additions, 1 deletion, 0 modifications)
2023-03-01 20:15:26.600 DEBUG 5868 --- [   File Watcher] rtingClassPathChangeChangedEventListener : Change set: [D:\code\spring\test\target\classes [D:\code\spring\test\target\classes\tk\lsq27\test\TestApplication.class (DELETE)]]
2023-03-01 20:15:26.601 DEBUG 5868 --- [   File Watcher] o.s.boot.devtools.restart.Restarter      : Restarting application
2023-03-01 20:15:26.603 DEBUG 5868 --- [       Thread-5] o.s.boot.devtools.restart.Restarter      : Stopping application
2023-03-01 20:15:26.686 DEBUG 5868 --- [       Thread-5] o.s.b.d.r.c.RestartClassLoader           : Created RestartClassLoader org.springframework.boot.devtools.restart.classloader.RestartClassLoader@d2ccc5d
2023-03-01 20:15:26.687 DEBUG 5868 --- [       Thread-5] o.s.boot.devtools.restart.Restarter      : Starting application tk.lsq27.test.TestApplication with URLs [file:/D:/code/spring/test/target/classes/]
2023-03-01 20:15:27.137  INFO 5868 --- [  restartedMain] tk.lsq27.test.TestApplication: Started TestApplication in 0.445 seconds (JVM running for 115.825)
2023-03-01 20:15:29.570  INFO 5868 --- [   File Watcher] rtingClassPathChangeChangedEventListener : Restarting due to 1 class path change (1 addition, 0 deletions, 0 modifications)
2023-03-01 20:15:29.570 DEBUG 5868 --- [   File Watcher] rtingClassPathChangeChangedEventListener : Change set: [D:\code\spring\test\target\classes [D:\code\spring\test\target\classes\tk\lsq27\test\TestApplication.class (ADD)]]
2023-03-01 20:15:29.570 DEBUG 5868 --- [   File Watcher] o.s.boot.devtools.restart.Restarter      : Restarting application
2023-03-01 20:15:29.571 DEBUG 5868 --- [       Thread-7] o.s.boot.devtools.restart.Restarter      : Stopping application
2023-03-01 20:15:29.634 DEBUG 5868 --- [       Thread-7] o.s.b.d.r.c.RestartClassLoader           : Created RestartClassLoader org.springframework.boot.devtools.restart.classloader.RestartClassLoader@600f3336
2023-03-01 20:15:29.634 DEBUG 5868 --- [       Thread-7] o.s.boot.devtools.restart.Restarter      : Starting application tk.lsq27.test.TestApplication with URLs [file:/D:/code/spring/test/target/classes/]

一个名为 File Watcher 的线程检测到 target 目录下的 TestApplication.class 被删除,Thread-5
线程将应用停止,创建 RestartClassLoader@d2ccc5d ,将应用启动,耗时 0.445
秒,重启完成后又检测到新增 TestApplication.class 文件,导致 Thread-7 线程将
应用又一次重启,此处我认为是一个设计上的缺陷,修改源代码并保存会导致 class 被删除、重新编译新增 class 两个操作,每次操作都会导致应用重启。

新建一个文件 TestService.java,同样会导致应用重启,日志如下:

2023-03-01 20:34:44.214  INFO 5868 --- [   File Watcher] rtingClassPathChangeChangedEventListener : Restarting due to 1 class path change (1 addition, 0 deletions, 0 modifications)
2023-03-01 20:34:44.214 DEBUG 5868 --- [   File Watcher] rtingClassPathChangeChangedEventListener : Change set: [D:\code\spring\test\target\classes [D:\code\spring\test\target\classes\tk\lsq27\test\TestService.class (ADD)]]
2023-03-01 20:34:44.214 DEBUG 5868 --- [   File Watcher] o.s.boot.devtools.restart.Restarter      : Restarting application
2023-03-01 20:34:44.216 DEBUG 5868 --- [      Thread-11] o.s.boot.devtools.restart.Restarter      : Stopping application
2023-03-01 20:34:44.285 DEBUG 5868 --- [      Thread-11] o.s.b.d.r.c.RestartClassLoader           : Created RestartClassLoader org.springframework.boot.devtools.restart.classloader.RestartClassLoader@797febdb
2023-03-01 20:34:44.286 DEBUG 5868 --- [      Thread-11] o.s.boot.devtools.restart.Restarter      : Starting application tk.lsq27.test.TestApplication with URLs [file:/D:/code/spring/test/target/classes/]

远程调试

spring-boot-devtools 还通过 HTTP 提供开箱即用的远程调试功能。首先,需要将 spring-boot-devtools 打包为应用程序的一部分。

<plugin>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-maven-plugin</artifactId>
    <configuration>
        <excludeDevtools>false</excludeDevtools>
    </configuration>
</plugin>

然后执行以下步骤:

  1. 将应用打包为JAR
  2. 使用JRE启动JAR包,增加参数 spring.devtools.remote.secret=password
  3. 在IDE中启动 org.springframework.boot.devtools.RemoteSpringApplication
    ,环境变量 spring.devtools.remote.secret=password,程序参数 http://localhost:8080
  4. 修改TestService.java并保存

RemoteSpringApplication 的日志如下:

2023-03-01 21:44:36.308  INFO 5800 --- [   File Watcher] o.s.b.d.r.c.ClassPathChangeUploader      : Uploading 1 class path change (0 additions, 1 deletion, 0 modifications)
2023-03-01 21:44:37.516  INFO 5800 --- [pool-1-thread-1] o.s.b.d.r.c.DelayedLiveReloadTrigger     : Remote server has changed, triggering LiveReload
2023-03-01 21:44:39.988  INFO 5800 --- [   File Watcher] o.s.b.d.r.c.ClassPathChangeUploader      : Uploading 1 class path change (1 addition, 0 deletions, 0 modifications)
2023-03-01 21:44:41.007  INFO 5800 --- [pool-1-thread-1] o.s.b.d.r.c.DelayedLiveReloadTrigger     : Remote server has changed, triggering LiveReload

RemoteSpringApplication 监视类路径中的更改,类路径中的任何更改都会导致将更新的资源推送到远程应用程序并触发重新启动。
可以看到,对文件的修改触发两次重启,和上一节的问题一样。

总结

spring-boot-devtools 通过自定义 ClassLoader 实现了应用的快速重启,虽有不足,但不失为应用开发人员的利器。


转载请注明出处,使用时须遵循 CC BY-SA 4.0 License 中所述条款。

标签:03,01,spring,boot,---,2023,devtools
From: https://www.cnblogs.com/lsq27/p/17170251.html

相关文章

  • 路飞:路飞前端全局css,全局配置文件、配置axios实现前后台交互、安装vue-cookies、安装e
    目录一、路飞前端全局css,全局配置文件1.1整理项目1.2设置全局css1.3配置全局js二、配置axios实现前后台交互三、安装vue-cookies四、安装elementui五、安装bootstrap和j......
  • SpringBoot——常用配置
    application.yml配置信息spring:profiles:active:devapplication:name:jwt-token-security#Jackson配置项jackson:serialization:......
  • SpringBoot自定义启动时的ASCII艺术字
    1.SpringBoot默认的艺术字2.进入ASCII艺术字网站https://www.bootschool.net/ascii3.把下载的banner.txt文件放在resource目录4.重新启动项目【注意:如果不生效的......
  • SpringBoot
    简介SprintBoot是一款快速开发框架,能够帮助我们快速整合第三方框架不同于SSM项目繁琐的xml配置,SpintBoot去除了xml配置全部采用注解化的方式配置内嵌Tomcat,运行就会启......
  • SpringBoot过滤器获取请求Body
    packagecom.example.springboot.core;importlombok.extern.slf4j.Slf4j;importorg.springframework.stereotype.Component;importjavax.servlet.http.HttpServle......
  • Springcore beanMap的使用
    default<SextendsV>Ssave1(Kkey,Sentity){IgniteCache<K,V>cache=cache();VtargetObject=cache.get(key);BeanMapsourceBean......
  • SpringBoot自定义拦截器和跨域配置冲突的问题
    跨域配置完成以后,又进行拦截器的配置,发现跨域配置失效,以下是原配置@ConfigurationpublicclassCORSConfigimplementsWebMvcConfigurer{@BeanpublicWebMv......
  • SpringCloud OpenFeign的使用
    SpringCloudOpenFeign的使用是什么:声明式http客户端。目的:使远程调用更简单作用:提供了http请求模板,仅需编写简单接口和插入注解,就可以定义好原始http请求的参数、格......
  • Spring_声明式事务
    编程式事务:由程序员编写事务控制代码,例如:OpenSessionInView。声明式事务:由框架提供的,程序员只需要声明出哪些方法要进行事务控制和如何进行事务控制。  ......
  • SpringBoot Actuator RCE 漏洞总结
    一、SpringBootenv获取*敏感信息 当我们直接访问springboot站点时,可以看到某些password字段填充了*通过${name}可以获取明文字段  2.配置不当导致敏感信息......