简体   繁体   English

SpringApplication.exit() retuns java.lang.InterruptedException: null

[英]SpringApplication.exit() retuns java.lang.InterruptedException: null

Recently, I have upgraded the spring boot version from 2.3.4 to 2.4.2 .最近,我将 spring 引导版本从2.3.4升级到2.4.2 I had below code to gracefully shutdown the application.我有下面的代码来优雅地关闭应用程序。

taskScheduler.schedule(() -> SpringApplication.exit(applicationContext, () -> 0),
            Instant.now().plus(30, ChronoUnit.SECONDS));

This piece of code was working fine before the upgrade.这段代码在升级之前运行良好。 Now it gives the below exception and application keep running (no termination).现在它给出了以下异常并且应用程序继续运行(没有终止)。

2021-02-08 18:56:29.530 WARN [xyz-naming-service,,] 9040 --- [ scheduling-1] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Interrupted during closing
java.lang.InterruptedException: null
at java.base/java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.awaitNanos(AbstractQueuedSynchronizer.java:2109)
at java.base/java.util.concurrent.ThreadPoolExecutor.awaitTermination(ThreadPoolExecutor.java:1454)
at com.zaxxer.hikari.pool.HikariPool.shutdown(HikariPool.java:255)
at com.zaxxer.hikari.HikariDataSource.close(HikariDataSource.java:351)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.base/java.lang.reflect.Method.invoke(Method.java:566)
at org.springframework.beans.factory.support.DisposableBeanAdapter.invokeCustomDestroyMethod(DisposableBeanAdapter.java:339)
at org.springframework.beans.factory.support.DisposableBeanAdapter.destroy(DisposableBeanAdapter.java:273)
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.destroyBean(DefaultSingletonBeanRegistry.java:587)
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.destroySingleton(DefaultSingletonBeanRegistry.java:559)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.destroySingleton(DefaultListableBeanFactory.java:1152)
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.destroySingletons(DefaultSingletonBeanRegistry.java:520)
at org.springframework.beans.factory.support.DefaultListableBeanFactory.destroySingletons(DefaultListableBeanFactory.java:1145)
at org.springframework.context.support.AbstractApplicationContext.destroyBeans(AbstractApplicationContext.java:1111)
at org.springframework.context.support.AbstractApplicationContext.doClose(AbstractApplicationContext.java:1080)
at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.doClose(ServletWebServerApplicationContext.java:171)
at org.springframework.context.support.AbstractApplicationContext.close(AbstractApplicationContext.java:1026)
at org.springframework.boot.SpringApplication.close(SpringApplication.java:1369)
at org.springframework.boot.SpringApplication.exit(SpringApplication.java:1356)
at com.xyz.renaming.Migrator.lambda$migrate$1(Migrator.java:36)
at org.springframework.scheduling.support.DelegatingErrorHandlingRunnable.run(DelegatingErrorHandlingRunnable.java:54)
at java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515)
at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264)
at java.base/java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:304)
at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1128)
at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:628)
at java.base/java.lang.Thread.run(Thread.java:834)

Any idea how to resolve this issue?知道如何解决这个问题吗?

Update :更新

Based on the @vvs answer, I change the code to close Hikari data source first.根据@vvs 的回答,我将代码更改为首先关闭 Hikari 数据源。 Now InterruptedException is not there.现在 InterruptedException 不存在。 Surprisingly, the application still running.令人惊讶的是,该应用程序仍在运行。 I could see below log keep logging frequently.我可以看到下面的日志经常记录。 Meaning, these thread didn't terminate.意思是,这些线程没有终止。

2021-02-09 15:46:40.460 INFO [xyz-naming-service,,] 3212 --- [ool-12-thread-1] o.a.k.c.c.internals.ConsumerCoordinator : ...

Think this is an issue in your application termination logic.认为这是您的应用程序终止逻辑中的一个问题。 Please have a look at this issue on HikariCP https://github.com/brettwooldridge/HikariCP/issues/1295请在 HikariCP https://github.com/brettwooldridge/HikariCP/issues/1295上查看此问题

The resolution says决议说

Looks like calling hikariDataSource.close() before SpringApplication.exit() fixes the issue看起来像在 SpringApplication.exit() 修复问题之前调用 hikariDataSource.close()

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

相关问题 Azure MobileService EasyApi java.lang.interruptedException - Azure MobileService EasyApi java.lang.interruptedException 使用swingworker的java.lang.InterruptedException - java.lang.InterruptedException using swingworker 未处理的异常:java.lang.InterruptedException - Unhandled Exception: java.lang.InterruptedException 引起原因:java.lang.RuntimeException:java.lang.InterruptedException - Caused by: java.lang.RuntimeException: java.lang.InterruptedException 使用Process.waitFor()和java.lang.InterruptedException的Java多线程 - java multithreading using Process.waitFor() and java.lang.InterruptedException 执行 Apache HttpClient 时出现 java.lang.InterruptedException - java.lang.InterruptedException while executing Apache HttpClient java.lang.InterruptedException导致Web应用程序无法部署 - java.lang.InterruptedException causes web application not deploy 运行批处理文件时出现 java.lang.InterruptedException - java.lang.InterruptedException while running a batch file ReactiveException: java.lang.InterruptedException 当我用@HystrixCommand 标记方法时 - ReactiveException: java.lang.InterruptedException when I mark method with @HystrixCommand 执行Java类时发生异常。 java.lang.InterruptedException - An exception occured while executing the Java class. java.lang.InterruptedException
 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM