Spring with Gradle-H2控制台未在localhost:8080 / h2-console中显示

时间:2018-10-15 15:54:09

标签: java spring spring-boot gradle h2

我下载了gradle,并指向现有的gradle文件创建了一个新项目。现在我想连接到H2.database。这是我的 build.gradle 文件:

plugins {
    id 'java'
    id 'org.springframework.boot' version '2.0.5.RELEASE'
    id "io.spring.dependency-management" version "1.0.6.RELEASE"
}
apply plugin: 'application'
apply plugin: 'idea'
group 'shop.hello.manualgradle'
version '1.0-SNAPSHOT'

sourceCompatibility = 1.8
mainClassName = 'hello.HelloWorld'

repositories {
    mavenCentral()
}

jar {
    baseName = 'gs-gradle'
    version = '0.1.0'
}
dependencies {
    testCompile group: 'junit', name: 'junit', version: '4.12'
    compile group: 'joda-time', name: 'joda-time', version: '2.2'
    compile 'org.springframework.boot:spring-boot-starter-web'
    compile 'org.springframework.boot:spring-boot-starter-data-jpa'
    compile 'com.h2database:h2'
    compile 'com.fasterxml.jackson.datatype:jackson-datatype-jsr310'

}

这是我在src / main / resources和src / test / resources中制作的 application.properties 文件

spring.datasource.name=ecommercedb
spring.jpa.show-sql=true
#H2 settings
spring.h2.console.enabled=true
spring.h2.console.path=/h2-console

我以gradle想法运行项目以更新依赖项,然后gradlew构建并运行gradlew。没有错误,但是当我转到localhost:8080 / h2-console时,我得到的是错误的连接。我也尝试过用gradle构建。为什么会这样呢?我也使用IntelIJ,而build和gradle文件夹为红色,为什么?我使用的是本指南:https://www.baeldung.com/spring-angular-ecommerce,但是我使用自己的gradle而不是Initializr,并且我在External Libraries中拥有Gradle:com.h2.database文件,因此我认为它应该可以工作!请帮助

2 个答案:

答案 0 :(得分:0)

您的Gradle构建看起来还不错,并且您的application.properties配置文件也正常。使H2控制台可用的唯一方法是像您一样设置属性spring.h2.console.enabled=true:这样就可以正常工作...无需配置datasource.url或凭据,Springboot将使用默认网址jdbc:h2:~/test

您应该尝试配置H2 db日志记录级别,并检查在启动应用程序或尝试访问H2控制台时是否可以看到错误/警告:在application.properties文件中添加以下属性

spring.datasource.url=jdbc:h2:~/test;TRACE_LEVEL_FILE=4

然后,在启动应用程序时,您应该看到如下痕迹:

2018-10-15 19:56:25.090 DEBUG 7576 --- [           main] h2database                               : test:jdbc[3] 
/**/conn0.clearWarnings();

尝试访问H2控制台时,您应该看到类似这样的痕迹:

 2018-10-15 19:57:21.179 DEBUG 7576 --- [nio-8080-exec-7] h2database                               : test:jdbc[13] Table      :     potential plan item cost 10 000 index meta

答案 1 :(得分:0)

我遇到了同样的问题,发现我的application.properties文件中spring.h2.console.path=/h2-console之后有尾随空格。这导致其路由错误。这是一个非常老的问题,但我认为我会添加解决问题的方法。

相关问题