之前的项目一直是启动类与Controller,Service,Mapper等包同级。Maven仅仅是引入其他模块或者第三方Jar包工具。
但是最新接手一套项目的架构非常有趣,也是记录一下分享一下,直接上示意图:
如果按照传统的模式,ABC每个子模块都会有各自的启动类。但是当前模式下:
上图一共五个Maven项目,父模块包含着四个子模块,子模块中有一个就是负责启动ABC那个子模块的启动类,ABC三套子模块中,又有各自的controller,service,mapper的包,然而仅需要ABC三个子模块的controller的包名路径一样(??最好要保持一致,不然该案例的配置会扫描不到controller!!假设为com.jojo.zoo),那么启动类指定扫描路径就写成:
@SpringBootApplication(scanBasePackages = {"com.jojo.zoo"})
然后还要在启动类模块的pom文件中,把ABC模块都引入进来即可
如果不想启动类模块直接引入ABC,那就在父模块中的引入ABC:
<dependencyManagement>
<dependencies>
<dependency>
<groupId>com.jojo.zoo</groupId>
<artifactId>jojo-A</artifactId>
<version>${jojo.version}</version>
</dependency>
<dependency>
<groupId>com.jojo.zoo</groupId>
<artifactId>jojo-B</artifactId>
<version>${jojo.version}</version>
</dependency>
<dependency>
<groupId>com.jojo.zoo</groupId>
<artifactId>jojo-C</artifactId>
<version>${jojo.version}</version>
</dependency>
</dependencies>
</dependencyManagement>
父模块的module必须包含ABC和启动类模块
<modules>
<module>jojo-start</module>
<module>jojo-A</module>
<module>jojo-B</module>
<module>jojo-C</module>
</modules>
这样更方便统一管理对应版本, 然后在XXX-Starter启动类模块的pom中加入:
<dependencies>
<dependency>
<groupId>com.jojo.zoo</groupId>
<artifactId>jojo-A</artifactId>
</dependency>
<dependency>
<groupId>com.jojo.zoo</groupId>
<artifactId>jojo-B</artifactId>
</dependency>
<dependency>
<groupId>com.jojo.zoo</groupId>
<artifactId>jojo-C</artifactId>
</dependency>
</dependencies>
这样就能正常启动,并且扫描到ABC三模块下的所有Controller了
为什么要这样拆分?
大佬说,部署的时候是用不到启动类的,所以根本不需要打包那一块代码,拆分出来更加整洁干净;同时也能更加灵活的组合对应模块,模块代码分离度更高
最后,任何情况下都要记得刷maven,clean + install
|