[英]Gradle Spring Boot Custom Configuration
我有一个使用mysql数据库来保存信息的应用程序。 我想创建一个使用嵌入式数据库( mariaDB4j
)的应用程序版本,并将其作为服务添加到我们的CI环境中,因此当我们通过端到端测试启动此嵌入式版本时,QA团队获得了清理数据库。
我在网上看了很多这个,看起来像gradle配置是要走的路。 我发现的最接近的是:
sourceSets {
qaci {
java {
srcDir 'src/qa/java'
}
compileClasspath += sourceSets.main.runtimeClasspath
compileClasspath += sourceSets.main.resources
}
}
configurations {
qaciCompile.extendsFrom compile
}
bootRepackage {
customConfiguration = myCustomConfig
}
不幸的是, bootRepackage
替换了bootJar
。 我正在使用gradle spring boot插件2.0.1.RELEASE
,当我尝试使用bootJar.customConfiguration
我收到一条错误消息,指出这是一个未知属性。
此外, mariaDB4j
需要配置类才能正常工作,我已将它包含在src/qa/java
并创建了一个新的源集以便添加它。
有谁知道如何告诉gradle spring boot插件使用自定义配置?
你有没有想过使用弹簧型材?
https://docs.spring.io/spring-boot/docs/current/reference/html/boot-features-profiles.html
它允许您为少数配置文件(即开发,QA,生产)定义一组不同的值,bean或配置集,您可以使用它们来运行具有不同配置或不同库的应用程序。
@Configuration
@Profile("production")
public class ProductionConfiguration {}
此类将加载您在.properties或.yml文件中为该配置文件设置的所有值。
要运行应用程序,您可以传递要用作命令行参数的配置文件
--spring.profiles.active=dev
mariaDB的配置将在特定的配置文件下。
例如(如果您使用的是yml):
spring:
profiles: QA
datasource:
url: jdbc:mariadb://qaserver:1234;databaseName=qaDatabase
username: USER
password: PASSWORD
driverClassName: org.mariadb.jdbc.Driver
//aditional mariadb properties, configs
spring:
profiles: production
datasource:
url: jdbc:sqlserver://proddatabase:1433;databaseName=production
username: USER
password: PASSWORD
driverClassName: com.microsoft.sqlserver.jdbc.SQLServerDriver
属于其他配置文件的类和属性将不会被处理。
将在您提供的本地路径中创建自动文件系统,以便您可以在重新启动/提供qa时还原数据。
- db文件的位置。 如果需要从头开始重新创建,请删除此目录
mariaDB4j.dataDir=./data/local
默认值是3306,所以使用3307以防它已经在这台机器上运行
mariaDB4j.port=3307
app.mariaDB4j.databaseName=app_alpha
spring.datasource.url=jdbc:mariadb://localhost:3307/
spring.datasource.username=root
spring.datasource.password=
spring.datasource.driver-class-name=org.mariadb.jdbc.Driver
spring.jpa.database-platform=org.hibernate.dialect.MySQL5InnoDBDialect
您可以参考这些以获取更多信息https://objectpartners.com/2017/06/19/using-mariadb4j-for-a-spring-boot-embedded-database/
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.