diff --git a/VIII. Build tool plugins/59.9. Understanding how the Gradle plugin works.md b/VIII. Build tool plugins/59.9. Understanding how the Gradle plugin works.md index e69de29..3165a0c 100644 --- a/VIII. Build tool plugins/59.9. Understanding how the Gradle plugin works.md +++ b/VIII. Build tool plugins/59.9. Understanding how the Gradle plugin works.md @@ -0,0 +1,22 @@ +### 59.9. 理解Gradle插件是如何工作的 + +当`spring-boot`被应用到你的Gradle项目,一个默认的名叫`bootRepackage`的任务被自动创建。`bootRepackage`任务依赖于Gradle `assemble`任务,当执行时,它会尝试找到所有限定符为空的jar artifacts(也就是说,tests和sources jars被自动跳过)。 + +由于`bootRepackage`查找'所有'创建jar artifacts的事实,Gradle任务执行的顺序就非常重要了。多数项目只创建一个单一的jar文件,所以通常这不是一个问题。然而,如果你正打算创建一个更复杂的,使用自定义`jar`和`BootRepackage`任务的项目setup,有几个方面需要考虑。 + +如果'仅仅'从项目创建自定义jar文件,你可以简单地禁用默认的`jar`和`bootRepackage`任务: +```gradle +jar.enabled = false +bootRepackage.enabled = false +``` +另一个选项是指示默认的`bootRepackage`任务只能使用一个默认的`jar`任务: +```gradle +bootRepackage.withJarTask = jar +``` +如果你有一个默认的项目setup,在该项目中,主(main)jar文件被创建和重新打包。并且,你仍旧想创建额外的自定义jars,你可以将自定义的repackage任务结合起来,然后使用`dependsOn`,这样`bootJars`任务就会在默认的`bootRepackage`任务执行以后运行: +```gradle +task bootJars +bootJars.dependsOn = [clientBoot1,clientBoot2,clientBoot3] +build.dependsOn(bootJars) +``` +上面所有方面经常用于避免一个已经创建的boot jar又被重新打包的情况。重新打包一个存在的boot jar不是什么大问题,但你可能会发现它包含不必要的依赖。