Сбой автоматической настройки источника данных при загрузке PostgreSql - PullRequest
0 голосов
/ 22 сентября 2018

Я настраиваю проект Springboot (версия 2.0.4) со сборкой maven для использования базы данных PostgreSQL.Я хочу использовать функцию автоматической настройки источника данных в Springboot, но она дает мне следующие ошибки:

Field dataSource in com.praveen.demo.MyController required a bean of type 'javax.sql.DataSource' that could not be found.
Bean method 'dataSource' not loaded because @ConditionalOnClass did not find required class 'org.springframework.jdbc.datasource.embedded.EmbeddedDatabaseType'
Bean method 'dataSource' not loaded because @ConditionalOnClass did not find required classes 'javax.transaction.TransactionManager', 'org.springframework.jdbc.datasource.embedded.EmbeddedDatabaseType'

В моем файле pom.xml у меня есть зависимости от postgresql и HikariCP, как показано ниже:

<dependency>
    <groupId>org.postgresql</groupId>
    <artifactId>postgresql</artifactId>
</dependency>

<dependency>
    <groupId>com.zaxxer</groupId>
    <artifactId>HikariCP</artifactId>
</dependency>

Также в моем файле application.properties

spring.datasource.url=jdbc:postgresql://localhost:5432/mydb?user=myself&password=mypassword

В моем Java-файле с аннотацией @RestController я добавляю источник данных, как показано ниже:

@Autowired
private DataSource dataSource;

Яниже artcile: https://docs.spring.io/spring-boot/docs/current/reference/html/boot-features-sql.html Я не хочу использовать JPA.Я считаю, что статья не предлагает использовать JPA для автоматической настройки для работы.Я ожидаю, что Spring boot должен автоматически настроить источник данных для приложения, так как я объявил зависимости и предоставил URL базы данных.Тем не менее я получаю ошибки (как указано выше) при запуске приложения.

Edit-1: я следую ниже статье: https://docs.spring.io/spring-boot/docs/current/reference/html/boot-features-sql.html

Edit-2: Complete POM:

<?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>

<groupId>com.praveen</groupId>
<artifactId>demo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>

<name>demo</name>
<description>Demo project for Spring Boot</description>

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.0.5.RELEASE</version>
    <relativePath/> <!-- lookup parent from repository -->
</parent>

<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
    <java.version>1.8</java.version>
</properties>

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

    <dependency>
        <groupId>org.postgresql</groupId>
        <artifactId>postgresql</artifactId>
    </dependency>


    <dependency>
      <groupId>com.zaxxer</groupId>
        <artifactId>HikariCP</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>
</dependencies>
<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
    </plugins>
</build>
</project>

Хотя меня все еще смущает документация, предоставленная на https://docs.spring.io/spring-boot/docs/current/reference/html/boot-features-sql.html, и я ожидал, что от меня не потребуется использовать JPA для автоматической настройки, если я явно объявляю зависимость от HikariCPи Postgresql.Закрытие пока.

1 Ответ

0 голосов
/ 22 сентября 2018

С вашим пом хорошо, если вы не хотите использовать JPA.

Определите @Bean для источника данных для настройки или добавления свойства в application.propoerties spring.datasource.type=com.zaxxer.hikari.HikariDataSource:

@Configuration
public class DbConfig {

    @Bean
    @ConfigurationProperties("spring.datasource")
    public HikariDataSource dataSource() {
        return DataSourceBuilder.create().type(HikariDataSource.class).build();
    }
}

и измените свои свойства на следующие:

spring.datasource.url=jdbc:postgresql://localhost:5432/mydb
spring.datasource.username-myself
spring.datasource.password= mypassword

Примечание: JPAсконфигурируйте для вас все, поэтому, если вы не используете JPA, вам нужно настроить DataSource, рассказав о Hikari.

Согласно справочному документу 29.1.2 Подключение к производственной базе данных

Если вы используете «стартеры» spring-boot-starter-jdbc или spring-boot-starter-data-jpa, вы автоматически получаете зависимость от HikariCP.

Вы можете полностью обойти этот алгоритм и указатьпул соединений, который нужно использовать, установив свойство spring.datasource.type.Это особенно важно, если вы запускаете приложение в контейнере Tomcat, так как tomcat-jdbc предоставляется по умолчанию.

[Совет] Дополнительные пулы соединений всегда можно настроить вручную.Если вы определяете свой собственный компонент DataSource, автоконфигурация не происходит.

...