在 Spring Boot 的同一个 pom.xml 中管理 H2 和 Postgres

Posted

技术标签:

【中文标题】在 Spring Boot 的同一个 pom.xml 中管理 H2 和 Postgres【英文标题】:Manage H2 and Postgres in same pom.xml in Spring Boot 【发布时间】:2019-10-19 21:30:48 【问题描述】:

我正在使用 Spring Boot 开发一个微服务应用程序。 我的应用程序将使用 Postgres DB 进行生产配置,并使用 Spring Boot 自动测试 H2 DB。 因此,我的 pom.xml 包含两个依赖项(H2 + Postgres)。我尝试将 H2 依赖项与 tes 范围相关联,并将 Postgres 与运行时相关联,如下所示:

        <dependency>
            <groupId>com.h2database</groupId>
            <artifactId>h2</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.postgresql</groupId>
            <artifactId>postgresql</artifactId>
            <scope>test</scope>
        </dependency>

我可以看到在运行 mvn test 时 Spring Boot 默认选择了我的单元测试环境中不存在的 postgres 数据库。这就是为什么我更喜欢使用 H2 来运行单元测试的原因。

是否有适当的方法告诉 Spring Boot 使用 H2 进行测试,否则使用 Postgres?

我不知道使用不同的 application.properties 文件(一个在 src/main/resources 中,另一个在 src/test/resources 中)是否可以解决问题。

【问题讨论】:

你的范围向后。 哦,对了!我会反转并检查。谢谢! @chrylis 反转运行时/范围没有解决问题。正如 g00glen00b 所解释的,运行时范围依赖项也将在测试范围内可用。 H2和Postgres之间还是会有冲突 【参考方案1】:

您应该知道有多个类路径,例如:

    编译时类路径, 运行时类路径, 测试类路径。

当您使用 &lt;scope&gt;runtime&lt;/scope&gt; 时,该依赖项将在 runtime classpathtesting classpath 中都可用,如 the documentation 所述:

这个范围表示依赖不是编译所必需的,而是执行所必需的。它在运行时和测试类路径中,但不在编译类路径中。

这意味着即使您正在执行测试,如果您使用 &lt;scope&gt;runtime&lt;/scope&gt;,Postgres 仍然会在您的类路径中。


您提到的解决方案,提供两个单独的application.properties 是正确的选择。

src/main/resources/application.properties 中,您可以像这样配置数据源:

spring.datasource.url=jdbc:postgresql://localhost:5432/mydatabase

src/test/resources/application.properties 中,您可以像这样配置数据源:

spring.datasource.url=jdbc:h2:mydatabase

如果您需要更细粒度的控制,可以使用 Spring 配置文件。例如,您可以使用名为“testdb”的配置文件,然后使用 @ActiveProfiles("testdb") 注释您的测试。

现在您可以创建一个名为 application-testdb.properties 的文件并添加设置测试数据库所需的属性。

【讨论】:

@HichemBOUSSETTA 请注意,通常最好使用配置文件而不是依赖覆盖文件名,并且尤其最好不要在源代码中包含凭据——使用环境运行时的变量。 是的,我已经非常感谢了!实际上,在这里我想最小化 ci 管道的配置。我正在寻找一种无需任何额外配置或秘密即可运行 mvn test 的方法 @g00glen00b 具有 2 个 application.properties 的解决方案,一个用于测试,另一个用于打包工作完美。谢谢! 如果我们在 pom 中有两个依赖,然后有 2 个独立的 application.properties,那么这种冲突就不会发生? @Mandroid 是的,如果您同时存在两个依赖项,那么您需要告诉 spring 它必须使用哪个驱动程序;您可以使用 spring 变量 spring.datasource.driver-class-name=xxx 根据您的需要使用一个或另一个驱动程序

以上是关于在 Spring Boot 的同一个 pom.xml 中管理 H2 和 Postgres的主要内容,如果未能解决你的问题,请参考以下文章

Spring Boot—19Session

《SpringCloud超级入门》Spring Boot项目搭建步骤(超详细)《六》

《SpringCloud超级入门》Spring Boot项目搭建步骤(超详细)《六》

(转)springboot:添加JSP支持

SpringBoot —程序包org.springframework.boot.test.context不存在

MyBatis学习总结——Mybatis3.x与Spring4.x整合