【问题标题】:Spring Boot: Failed to configure a DataSource: 'url' attribute is not specified and no embedded datasource could be configuredSpring Boot:无法配置数据源:未指定“url”属性,并且无法配置嵌入式数据源
【发布时间】:2019-08-24 04:02:34
【问题描述】:

当我运行我的网络应用程序时引发以下错误。

Exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaConfiguration': Unsatisfied dependency expressed through constructor parameter 0; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'dataSource' defined in class path resource [org/springframework/boot/autoconfigure/jdbc/DataSourceConfiguration$Hikari.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [com.zaxxer.hikari.HikariDataSource]: Factory method 'dataSource' threw exception; nested exception is org.springframework.boot.autoconfigure.jdbc.DataSourceProperties$DataSourceBeanCreationException: Failed to determine a suitable driver class

抛出的错误描述如下,

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:<br>
        If you want an embedded database (H2, HSQL or Derby), please put it on the classpath.
<br>    If you have database settings to be loaded from a particular profile you may need to activate it (no profiles are currently active).

在参考this answer 之后,我知道我必须对我的pom.xml 文件进行一些更改。但我不知道要改变什么,甚至 StackOverflow 上的类似问题也无法帮助我解决这个问题。

我的pom.xml如下(我在创建项目时添加了“Web”、“JPA”、“MySQL”依赖项),

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
        <parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>2.1.3.RELEASE</version>
            <relativePath/> <!-- lookup parent from repository -->
        </parent>
        <groupId>com.example</groupId>
        <artifactId>SL2INDUSTRY</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <name>SL2INDUSTRY</name>
        <description>Demo project for Spring Boot</description>

        <properties>
            <java.version>1.8</java.version>
        </properties>

        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-data-jpa</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>

            <dependency>
                <groupId>mysql</groupId>
                <artifactId>mysql-connector-java</artifactId>
                <scope>runtime</scope>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-test</artifactId>
                <scope>test</scope>
            </dependency>
            <!-- https://mvnrepository.com/artifact/org.apache.tomcat.embed/tomcat-embed-jasper -->
            <dependency>
                <groupId>org.apache.tomcat.embed</groupId>
                <artifactId>tomcat-embed-jasper</artifactId>
                <scope>provided</scope>
            </dependency>

            <!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-tomcat -->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-tomcat</artifactId>
                <version>2.1.3.RELEASE</version>
            </dependency>

            <!-- https://mvnrepository.com/artifact/com.fasterxml.jackson.dataformat/jackson-dataformat-xml -->
            <dependency>
                <groupId>com.fasterxml.jackson.dataformat</groupId>
                <artifactId>jackson-dataformat-xml</artifactId>
                <version>2.9.8</version>
            </dependency>
        </dependencies>

        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                </plugin>
            </plugins>
        </build>

    </project>

请注意,在这种情况下我不需要处理 H2 数据库,因此 H2 不适合我。

编辑: application.properties文件

spring.mvc.view.suffix=.jsp

【问题讨论】:

  • 能否添加有问题的application.properties文件内容。

标签: java spring spring-boot


【解决方案1】:

这有几种可能,但第一次你需要做三件事。

1 - 您对 pom.xml 的依赖项的特定兼容版本

2 - 您需要在 pom.xml 上添加数据库驱动程序连接器

3 - 在 'src/main/resources/application.properties' 目录上创建一个 application.properties 并将您的数据库配置放在那里。

application.properties(注意:使用数据库配置更改 de 值)

spring.jpa.hibernate.ddl-auto=create

spring.datasource.url=jdbc:mysql://localhost:3306/db_example

spring.datasource.username=user

spring.datasource.password=ThePassword

您可以在此处查看模板: https://spring.io/guides/gs/accessing-data-mysql/

【讨论】:

  • 错误原因是我在创建项目时选择的 MySQL 依赖项
  • 如果我不选择它,项目工作正常但问题是我需要使用 MySQL
  • 可能是你的依赖有冲突,试试去掉tomcat-embed-jasper的依赖,用tomcat不需要那个,spring-boot-starter-tomcat就够了。如果问题仍然存在,请分享您的文件 application-spring-boot.java 和 application.properties
  • 再次检查我上面的回复,我使用 spring.datasources 属性进行了编辑,您需要在 application.properties 中添加。
【解决方案2】:

如果您阅读了您的错误痕迹:

Exception encountered during context initialization - cancelling refresh attempt: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'org.springframework.boot.autoconfigure.orm.jpa.HibernateJpaConfiguration': Unsatisfied dependency expressed through constructor parameter 0; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'dataSource' defined in class path resource [org/springframework/boot/autoconfigure/jdbc/DataSourceConfiguration$Hikari.class]: Bean instantiation via factory method failed; nested exception is org.springframework.beans.BeanInstantiationException: Failed to instantiate [com.zaxxer.hikari.HikariDataSource]: Factory method 'dataSource' threw exception; nested exception is org.springframework.boot.autoconfigure.jdbc.DataSourceProperties$DataSourceBeanCreationException: Failed to determine a suitable driver class

您会注意到他正在尝试使用 hikari 数据源来配置与 bd 的连接。这是怎么回事?

你使用的是spring boot 2。而这个版本的spring boot已经改变了默认配置。

你可以在这个地址看到:

https://www.baeldung.com/spring-boot-hikari#spring-boot-2

在 Spring Boot 2 中,Hikari 是默认的 DataSource 实现。

这是 Spring Boot 1.x 的变化:

· 对 Hikari 的依赖现在自动包含在 spring-boot-starter-data-jpa 中

· 自动确定数据源实现的发现算法现在更喜欢 Hikari 而不是 TomcatJDBC(请参阅参考手册)。

因此,如果我们想在基于 Spring Boot 2.x 的应用程序中使用 Hikari。

而且Hikari的配置不同。

然后,我想你想使用 tomcat 连接池。你可以这样做:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-jpa</artifactId>
    <exclusions>
        <exclusion>
            <groupId>com.zaxxer</groupId>
            <artifactId>HikariCP</artifactId>
        </exclusion>
    </exclusions>
</dependency>
<dependency>
    <groupId>org.apache.tomcat</groupId>
    <artifactId>tomcat-jdbc</artifactId>
    <version>9.0.10</version>
</dependency>

默认情况下,这将从您的 spring jpa 配置中排除 Hikari,然后您将需要 tomcat-jdbc。您可以配置数据源:

这种简单的方法允许我们使用 Tomcat 连接池来获取 Spring Boot,而无需编写 @Configuration 类并以编程方式定义 DataSource bean。

还值得注意的是,在本例中,我们使用的是 H2 内存数据库。 Spring Boot 将为我们自动配置 H2,无需指定数据库 URL、用户和密码。

我们只需要在“pom.xml”文件中包含相应的依赖,Spring Boot 会为我们完成剩下的工作。

或者,可以跳过 Spring Boot 使用的连接池扫描算法,并使用“spring.datasource.type”属性在“application.properties”文件中明确指定连接池数据源:

spring.datasource.type=org.apache.tomcat.jdbc.pool.DataSource
// other spring datasource properties
spring.datasource.url=...
spring.datasource.username=...
spring.datasource.password=...
...

这里有禁用 Hikari 和配置 tomcat 的完整参考:

https://www.baeldung.com/spring-boot-tomcat-connection-pool

如果你想使用 Hikari,配置是不同的:

https://www.baeldung.com/spring-boot-hikari

但这两个选项之一将解决您的问题。

【讨论】:

    猜你喜欢
    • 2021-03-18
    • 2022-07-21
    • 2019-08-07
    • 2019-03-25
    • 2023-02-21
    • 2019-10-30
    • 2020-05-31
    • 1970-01-01
    • 2021-05-14
    相关资源
    最近更新 更多