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).
说明:
未能配置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})
- 第二种情况,给数据源配置上对应的属性值,用于自动配置类的属性值使用。
说明:如果是第二种情况,重点应该放在排查是否有配置数据源(datasource)相关的属性值,或者配置了属性值为什么没有生效。 比如使用Nacos配置中心时,datasource相关的属性是否生效了。