Skip to content
muggle edited this page Apr 15, 2020 · 16 revisions

原模块已切换到study分支,master分支以实用性为主,最新文档地址

该项目每个功能模块都是单独的一个maven模块,模块与模块之间松耦合,通过manager层来调用(common 和core 被所有项目直接依赖引用),这意味着你可以将某个模块单独拆分出来应用到你的项目之中。项目还在建设改进中,欢迎小伙伴们fork和star

关于项目架构的一些小心得

1.模块分类原则

模块分为三类,一类是项目的基础模块,包括common和core;一类是功能模块,不涉及任何业务代码,只是单纯的功能实现;一类是业务模块,所有与业务不相干的方法和类不能出现在其中; 这三类模块依赖关系及其功能是这样的:common为通用模块,用于存放DTO和工具类和一些base接口

项目架构技巧:基于common 和core模块 manager层的简单解耦

我的项目是将功能模块和业务模块划分开的;功能部分拆分成多个模块,业务部分拆分成多个模块。业务模块可以任意依赖功能模块。功能模块和功能模块之间原则上应该是松耦合的,既功能模块之间是不相互依赖的,如何能做到呢? 答案是利用好common和core模块,通常的,我们可以将一些公共类放到common中,这样所有模块要使用公共类只要引用common即可;而一些特殊的情况比如 a功能模块需要使用b功能模块的类这种情况如何解决?在core中定义好接口 b的类继承这个接口,然后注入到spring,a从spring中拿这个bean,这样a就不必依赖b,达到解耦的目的。

举例: 现假设有一个redis模块,一个rabbitMQ模块,rabbitMQ模块需要使用redis模块的类;

记住,我们不直接从rabbitMQ模块中依赖redis模块(直接依赖的缺点显而易见,移植性很差),我们在core中定义一个接口:

public interface TestRedis{}

在redis模块中实现这个接口并注入到spring:

@service
public class testRedisImpl implements TestRedis{
}

在rabbitMQ模块中拿这个类:

public class test{
   @Autowired
   TestRedis testRedis;
}

这样就比较简单的实现了模块间解耦;

manager层的使用

我的分层原则是service层只能给controller层使用,而manager层出现的目的就是供其他service层使用,就是说service不直接调用service,而是通过manager来做调用;这样做的好处是:

1.manager层相当于一个门面模式,方便代码的统一管理。 2.service层可以只专注于业务逻辑等或功能,以遵循单一职责的原则

关于manager层的详细细节,阿里java规范里面有具体说明。 我项目中部分功能模块并未完全遵守以上原则,是因为项目早期的架构的时候思路和经验的问题遗留下来的,希望大家注意。

我看过有的项目架构以三层模型来分模块,也就是分成了service模块,controller模块,dao模块等。我觉得这样分模块并未发挥maven多模块的优势,代码移植性,和便于管理的程度都不是很好;相对来说我这种分模块的思路更具有优势。

还有要注意一点,各个模块的包名要统一,这是因为springboot的自动扫描的特性——扫描同级和下级包路径下的bean,因此,包名要统一。

maven配置需注意的细节

maven 配置的一些小细节也需注意: parent的 relativePath要指定好位置

<parent>
        <groupId>com.muggle.poseidon</groupId>
        <artifactId>poseidon-parent</artifactId>
        <version> 0.1.0.BUILD</version>
        <relativePath>../poseidon-parent/pom.xml</relativePath>
       
    </parent>

对于自己的模块应该在父pom(parent)中 用dependencyManagement 管理好版本号:

<properties>
        <poseidon.version>0.1.0.BUILD</poseidon.version>
</properties>

<dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>com.muggle.poseidon</groupId>
                <artifactId>poseidon-common</artifactId>
                <version>${poseidon.version}</version>
            </dependency>
  </dependencies>
</dependencyManagement>

对项目中的静态资源,应该在pom中申明,否则可能会发生找不到的情况:

<resources>
   <resource>
        <directory>src/main/resources</directory>
           <includes>
               <include>**/*.properties</include>
               <include>**/*.xml</include>
               <include>**/*.html</include>
               <include>**/*.jsp</include>
               <include>**/*.txt</include>
                <include>**/*.jpg</include>
             </includes>
    <!--<filtering>false</filtering>-->
    </resource>
       <resource>
         <directory>src/main/java</directory>
           <includes>
              <include>**/*.properties</include>
              <include>**/*.xml</include>
              </includes>
           <!--<filtering>false</filtering>-->
        </resource>
   </resources>

还要注意packaging节点,父pom应该是pom,而子pom应该是war或者jar