【Bug解决】Failed to configure a DataSource

1、问题描述

SpringBoot项目在启动时报出下面的错误:

Description:

Failed to configure a DataSource: 'url' attribute is not specified and no embedded datasource could be configured.

Reason: Failed to determine a suitable driver class

Action:

Consider the following:

If you want an embedded database (H2, HSQL or Derby), please put it on the classpath.

If you have database settings to be loaded from a particular profile you may need to activate it (no profiles are currently active).

【Bug解决】Failed to configure a DataSource_第1张图片

说明:

未能配置DataSource:未指定“url”特性,也无法配置任何嵌入的数据源。

原因:无法确定合适的驱动程序类别

操作:

考虑以下内容:

如果您想要一个嵌入式数据库(H2、HSQL或Derby),请将其放在类路径中。

如果您有要从特定配置文件加载的数据库设置,则可能需要激活它(当前没有激活的配置文件)。

2、问题分析

  • 从报错信息中,可看到是未能配置DataSource:未指定“url”特性,也无法配置任何嵌入的数据源。换句话说,我们没有配置DataSource(数据源)的url属性值。
  • 那在什么情况下会要求我们配置数据源的url属性呢? 在触发加载数据源的自动配置类时需要配置相关属性。
  • 因为通常情况下,是在yml文件中配置数据源相关内容,通过这种方式我们可以知道,数据源的配置是由SpringBoot实现了自动配置的。通常是因为我们引入了mybatis-spring-boot-starter启动器等一类与数据源连接相关的依赖,触发了数据源创建对应的自动配置类。
  • 所以,解决方案有两种,一是不让SpringBoot创建数据源的自动配置类;二是给数据源自动配置类的属性赋值。

3、问题解决

  • 第一种情况:不加载数据源的自动配置类,适用于不连接相关的数据库。只需要在启动类上使用自动配置的注解EnableAutoConfiguration将自动配置类DataSourceAutoConfiguration.class排除。

@EnableAutoConfiguration(exclude={DataSourceAutoConfiguration.class})

【Bug解决】Failed to configure a DataSource_第2张图片

  • 第二种情况,给数据源配置上对应的属性值,用于自动配置类的属性值使用。

【Bug解决】Failed to configure a DataSource_第3张图片

说明:如果是第二种情况,重点应该放在排查是否有配置数据源(datasource)相关的属性值,或者配置了属性值为什么没有生效。 比如使用Nacos配置中心时,datasource相关的属性是否生效了。

你可能感兴趣的:(spring,boot,mybatis,java)