遇到这个问题时查了许多博主的信息,此处仅为个人方面的总结(汇总但并不全面)
参考信息来源:
彻底解决Failed to configure a DataSource: ‘url‘ attribute is not specified and no embedded datasourcehttps://blog.csdn.net/renkai721/article/details/112257894springboot项目 o.s.b.d.LoggingFailureAnalysisReporter 错误解决方法https://blog.csdn.net/weixin_39872341/article/details/105419983com.mysql.jdbc.Driver 和 com.mysql.cj.jdbc.Driver 的区别https://blog.csdn.net/a907691592/article/details/96876030
报错代码、信息如下:
Error starting ApplicationContext. To display the conditions report re-run your application with 'debug' enabled.
2023-07-02 22:02:05.181 ERROR 116952 --- [ main] o.s.b.d.LoggingFailureAnalysisReporter :
***************************
APPLICATION FAILED TO START
***************************
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).
Process finished with exit code 1
错误信息翻译:
Failed to configure a DataSource: 'url' attribute is not specified and no embedded datasource could be configured.
(配置数据源失败:“url”属性未指定,无法配置嵌入数据源)
Reason: Failed to determine a suitable driver class
(原因:无法确定合适的驱动程序类)
报错原因
在项目启动时,Spring Boot会默认加载org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration 这个类,而DataSourceAutoConfiguration类使用了@Configuration注解向spring注入了dataSource bean。因为工程中没有关于dataSource相关的配置信息,当spring创建dataSource bean因缺少相关的信息就会报错。
解决办法一般分两种情况
第一种情况:项目不需要连接数据库,启动时报错
解决办法:在配置类注解@SpringBootApplication 后面加上 (exclude ={DataSourceAutoConfiguration.class}) 即可。
@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
//@SpringBootApplication
**@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class}):**
这个注解的作用是:排除自动注入数据源的配置(即取消数据库的配置)。
DataSourceAutoConfiguration.class会自动查找**配置文件**(application.properties或者
application.yml)中的相关数据源配置信息。
另外,DataSourceAutoConfiguration.class默认会自动配置**单数据源**,如果想在项目中使用多数据源就需要排除(exlcude)它,再手动指定多数据源。
第二种情况:项目需要连接数据库,启动时报错
解决方案①:在配置文件中没有添加数据库配置信息,则需要编写相应的配置
yml配置示例:
注意,yml配置文件中在设置值时,冒号后面要加上一个空格,这是yml的基本语法。
spring:
datasource:
url: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8&useSSL=false
username: root
password: 123456
driver-class-name: com.mysql.jdbc.Driver
properties配置示例:
spring.datasource.url=jdbc:mysql://localhost:3306/test?setUnicode=true&characterEncoding=utf8
spring.datasource.name=root
spring.datasource.password=123456
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
另外,由于mysql的版本不同,相应的 ur l和 driver-class-name 设置的值也有所不同,具体参考
com.mysql.jdbc.Driver 和 com.mysql.cj.jdbc.Driver 的区别
解决方案②:项目没有加载到yml或者properties文件,特别是自己的pom打包是jar的项目,需要查看自己的pom.xml文件中的packaging
<packaging>jar</packaging>
如果pom中指定使用jar,系统不会自动读取到yml或者properties文件的,需要我们手动配置pom.xml。
<!--build放在</dependencies>标签的后面,主要加入的是resources标签 -->
<!--resources标签可以告诉系统启动的时候能够读取到这些后缀的文件 -->
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
<resources>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.yml</include>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>false</filtering>
</resource>
<resource>
<directory>src/main/resources</directory>
<includes>
<include>**/*.yml</include>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>false</filtering>
</resource>
<resource>
<directory>lib</directory>
<includes>
<include>**/*.jar</include>
</includes>
</resource>
</resources>
</build>
解决方案③:项目使用 Profile多环境支持,但未加载到正确的配置文件
默认情况下,spring boot使用application.properties配置文件
解决办法:手动指定profile(4种方式)
以当前需要指定的配置文件名为 application-dev.properties 为例
方式一:在配置文件中指定spring.profiles.active={profile}
properties示例:
spring.proflies.active=dev
yml示例(yml支持多文档块方式):
方式二:命令行指定 --spring.profiles.active=dev
方式三:控制台指定(将项目打包后在控制台运行时调用指令)
java -jar jar包名 --spring.profiles.active=dev
方式四:虚拟机参数指定
-Dspring.profiles.active=dev
解决方案④:项目使用了springcloud+nacos系列
启动项目时候需要手动指定【--spring.profiles.active=test】,那么在resources文件夹下就必须要有bootstrap-test.yml或者application-test.yml文件,同时配置文件中连接的nacos地址里面也必须配置对应的命名空间,和对应服务名称的yml文件,否则也是报错。下面是配置文件的截图
当然,这只是解决一部分报错的方案,具体解决办法还需参考项目Description提供的报错信息。例如端口号被占用时也会报出o.s.b.d.LoggingFailureAnalysisReporter的错误信息,这时候就需要更改端口号,方法也很多,就比如在配置文件中指定server.port=8081(默认值8080)等。
版权归原作者 峰子的番茄肥牛 所有, 如有侵权,请联系我们删除。