spring-boot - H2 控制台 Spring Boot 未打开

标签 spring-boot h2

我有非常简单的项目 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
         https://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.2.5.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <packaging>jar</packaging>
    <groupId>com.example</groupId>
    <artifactId>managing-transactions</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>managing-transactions</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-jdbc</artifactId>
        </dependency>

        <dependency>
            <groupId>com.h2database</groupId>
            <artifactId>h2</artifactId>
            <scope>compile</scope>
        </dependency>
    </dependencies>

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

在 appliation.properties 中我尝试了不同的变体

#spring.datasource.url=jdbc:h2:mem:testdb
spring.datasource.url=jdbc:h2:mem:test;DB_CLOSE_DELAY=-1
spring.datasource.driverClassName=org.h2.Driver
spring.datasource.username=sa
spring.jpa.database-platform=org.hibernate.dialect.H2Dialect
spring.h2.console.enabled=true
spring.h2.console.path=/h2-console

但控制台在 http://localhost:8080/h2-console 上打不开

唯一的办法就是用老办法

Runnable runServer = new Runnable() {
    @Override
    public void run() {
        try {
            Server.startWebServer(DriverManager.getConnection("jdbc:h2:mem:test;DB_CLOSE_DELAY=-1", "sa", ""));
        } catch (SQLException e) {
            e.printStackTrace();
        }
    }
};
Thread threadServer = new Thread(runServer);
threadServer.start();

最佳答案

这似乎不是特定于 H2 配置的问题。当我尝试使用相同的 Maven 依赖项时,我看到应用程序启动和停止。

要在您自己的 Spring Boot 项目中查看 H2 控制台,需要运行 Spring 嵌入式 Web 服务器 - 这是为了使“h2-console”url 起作用。

所以不要单独使用 JDBC 项目:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-jdbc</artifactId>
</dependency>

使用带有简单 Controller 的 starter-web 项目。

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

或者将 Spring Dev 工具依赖项添加到您的代码中。这将使服务器持续运行,并且 H2 控制台 URL 将起作用。

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-devtools</artifactId>
    <optional>true</optional>
</dependency>

这里是完整源代码的链接。 https://github.com/shankarps/H2Project

如果您不想运行 web-starter 项目,您也可以使用 Spring Dev 工具。

这是一篇包含更多详细信息的文章 - https://medium.com/@harittweets/how-to-connect-to-h2-database-during-development-testing-using-spring-boot-44bbb287570

关于spring-boot - H2 控制台 Spring Boot 未打开,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60762845/

相关文章:

java - Java 中的 Hibernate 映射 : org. hibernate.MappingException:实体映射中的重复列

sql - H2 TRUNC 功能缺陷

java - Dockerized Spring Boot 应用程序不使用挂载的 Kubernetes ConfigMap (application.properties)

spring-boot - 即时通讯无法将我的mysql查询转换为elasticsearch查询

spring - 配置为监听端口 8080 的 Tomcat 连接器失败

java - 如何在 Spring Boot 中发送请求范围 bean 作为响应

java - H2数据库支持滚动吗

sql - h2 是否支持使用辅助键创建表?

java - 如何从java启动H2

java - 如何在 Swagger 2 中为每个端点放置不同的示例?