DataSourceClosedException_ dataSource already closed

修改了项目中kafka相关配置,准备上线,控制台一直报错:
在这里插入图片描述
一直不停的在刷数据库连接池已关闭???

只改了kafka相关的配置,为什么数据库连接池一直在报错?即使kafka配置写错了,kafkaConsumer不能被注入为Springbean那服务也应该直接启动失败,程序终止,而不是一直在刷error

遇事不决先把控制台的日志翻到最顶,仔细查看第一个报错的日志:

在这里插入图片描述

这里已经提示的很明显了,key.deserializer没有默认值,于是kafkaConsumerbean创建失败

 Exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'myConsumer' defined in file [D:\source_code\...Consumer.class]: Bean instantiation via constructor failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [....Consumer]: Constructor threw exception; nested exception is org.apache.kafka.common.config.ConfigException: Missing required configuration "key.deserializer" which has no default value.

然后服务启动失败:
[外链图片转存中...(img-5olxhgeN-1734884049485)]

服务启动失败的时候,首先就closedataSource,这也就解释了为什么后面一直报错: dataSource already closed,因为服务启动失败了数据连接池关闭了,但是为什么控制台一直在刷?停不下来?

后来搜索了下相关资料:

在标准的Java应用程序中,如果主线程(通常是执行main方法的那个线程)结束执行,但是还有其他非守护(non-daemon)线程在运行,JVM将不会退出,在Spring容器关闭或者服务启动失败的情况下,如果JVM没有完全退出,那么之前已经启动的线程池不会自动销毁。线程池中的线程会继续运行直到它们完成当前任务,或者直到JVM被明确地告知要关闭。如果没有显式地关闭线程池,这些线程可能会继续尝试执行,即使它们依赖的资源(比如数据库连接池)已经被释放。
在正常的重启过程中,应用程序的JVM(Java虚拟机)实例将被关闭。当JVM退出时,它会终止运行在其中的所有线程,包括那些可能仍在执行的线程池中的线程。这意味着,即使线程池没有被显式关闭,JVM的关闭也将确保所有线程最终终止。 

意思是:即使我们bean注入失败了,程序启动失败了,但是因为在程序启动的时候在程序中开启了非守护线程,且一直在运行,在Spring程序关闭的时候没有做正确的关闭处理,例如:线程池资源释放shutDown等,那么这些被开启的线程就会一直运行,JVM因为这些非守护线程在执行也不会退出。

在这个项目中确实在Spring程序启动时,开启了一个线程池去一直循环修改数据库表数据,不会停下,于是在程序启动失败的时候数据库连接池关闭了,但是一直在报错: dataSource already closed。后面实验确实如此,代码如下:

@Configuration
public class TestConfiguration {


    public TestConfiguration() {
        new Thread(new Runnable() {
            @Override
            public void run() {
                while (true) {
                    try {
                        Thread.sleep(1000);
                    } catch (InterruptedException e) {
                        throw new RuntimeException(e);
                    }
                    System.out.println("会一直循环");
                }
            }
        }).start();
    }

    @Bean
    public void test1() {
        int a = 1 / 0;
    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值