0


解决SpringBoot启动报错 :o.s.b.d.LoggingFailureAnalysisReporter

遇到这个问题时查了许多博主的信息,此处仅为个人方面的总结(汇总但并不全面)

参考信息来源:

彻底解决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)等。

本文转载自: https://blog.csdn.net/weixin_63453779/article/details/131506225
版权归原作者 峰子的番茄肥牛 所有, 如有侵权,请联系我们删除。

“解决SpringBoot启动报错 :o.s.b.d.LoggingFailureAnalysisReporter”的评论:

还没有评论