Gradle web 项目多环境打包配置

因为需要不同的项目配置所以要通过gradle或者maven来切换环境

1、目录结构

在这里插入图片描述

filters 存储的是不同环境的配置信息

2、build.gradle

核心代码如下

import org.apache.tools.ant.filters.ReplaceTokens
group 'com.ai'
version '1.0-SNAPSHOT'

// gradle 环境分离配置 打包参数-Dprofile=product
def env = System.getProperty("profile") ?: "dev"

if (env == "dev") {
    sourceSets {
        main {
            resources {
                srcDirs = ["src/main/resources"]
            }
        }
    }
} else {
    sourceSets {
        main {
            resources {
                srcDirs = ["src/main/filters/$env"]
            }
        }
    }
}

/** 覆盖web.xml配置文件 **/
task copyConfig(type:Copy) {
    println "config file"
    from 'src/main/filters/web.xml'
    into file('src/main/webapp/WEB-INF')
}
/** 在war任务之前执行替换文件任务 **/
war.dependsOn copyConfig

环境的区分:

  1. -Dprofile=product生产环境
  2. -Dprofile=dev 开发环境

配置文件替换:
根据不同的环境配置不同的resources,这里存放的是一些Spring配置文件,jdbc配置文件。根据不同的环境变量变更>resources的目录即可达到切换配置文件的目的。
web.xml替换:比较特殊的是web.xml文件无法替换,只有通过打war包时进行替换,不能是在build之前这是犯过错误的。
war.dependsOn 在打war包之前执行一个任务来替换web.xml,这个任务也可以根据不同的profile进行配置不同的web.xml替换。web.xml本地也会被替换成指定的内容,这时就需要恢复一下本地文件了。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Gradle的多模块项目中使用Spring Boot打包时,需要在每个模块中配置相应的构建脚本build.gradle文件。以下是一个示例: 1. 在根目录的build.gradle中添加以下代码: ```groovy subprojects { apply plugin: 'java' apply plugin: 'org.springframework.boot' apply plugin: 'io.spring.dependency-management' repositories { mavenCentral() } dependencies { compile('org.springframework.boot:spring-boot-starter-web') testCompile('org.springframework.boot:spring-boot-starter-test') } jar { baseName = "${project.name}" version = "${project.version}" } bootJar { baseName = "${project.name}" version = "${project.version}" } } ``` 2. 在每个模块的build.gradle中添加以下代码: ```groovy apply plugin: 'java' apply plugin: 'io.spring.dependency-management' dependencies { implementation project(':module-name') compile('org.springframework.boot:spring-boot-starter-web') testCompile('org.springframework.boot:spring-boot-starter-test') } jar { baseName = "${project.name}" version = "${project.version}" } bootJar { baseName = "${project.name}" version = "${project.version}" } ``` 其中,`module-name`为该模块依赖的其他模块的名称。 3. 在根目录下执行`./gradlew build`命令即可打包所有模块。在每个模块的build/libs目录下会生成相应的jar包和可执行的bootJar文件。 注意:如果需要将多个模块打包成一个可执行的jar包,可以在根目录下的build.gradle文件中添加以下代码: ```groovy task fatJar(type: Jar) { manifest { attributes 'Main-Class': 'com.example.Application' } baseName = "${rootProject.name}-all" version = "${rootProject.version}" from { configurations.compile.collect { it.isDirectory() ? it : zipTree(it) } } with jar } ``` 其中,`com.example.Application`为启动类的全限定名。执行`./gradlew fatJar`命令即可在根目录下生成一个可执行的jar包。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值