File -> New -> project,选择maven-archetype-site,如下图
父pom的packaging改为pom。比如创建父pom为hulk-parent
用于提供dubbo服务api
右键父pom,比如hulk-parent,选择New->module,直接next,不要勾选create from archetype,如下图
接着在parent这里不要选择hulk-parent,原因是对于dubbo api模块,是要提供jar依赖给别人使用,如果其parent是hulk-parent,那么需要把hulk-parent也要推送到仓库,别人才可以拉取到hulk-api模块,这样是不规范的,因此这里要选择none,这样只把hulk-api模块推送到仓库,别人即可下载到hulk-api依赖
创建common、mapper、service模块
通常项目都有common、mapper模块,创建这两个模块,parent选择hulk-parent
同样创建module不要勾选create from archetype,parent处是父pom,即hulk-parent
一个项目通用工程就是这样了,当然也可以加web、schedule、mq模块
一个完整的项目maven结构如下
hulk-parent
|-hulk-api --> dubbo api模块,给别人依赖,提供服务
|-hulk-common --> 通用模块
|-hulk-mapper --> 数据库模块,放数据库实体和mapper
|-hulk-service --> 服务的具体实现,包含dubbo服务和业务服务。通常作为一个应用
|-hulk-web --> web模块,提供http能力,通常作为一个应用
|-hulk-schedule --> job模块,通常用于补偿、定时操作等,通常作为一个应用
实际结构如下图
父pom的模块如下图,里面不包含dubbo api模块
为什么比如hulk-service依赖hulk-common,但是hulk-common不需要推送到maven呢?
比如采用jenkins构建,这些都在一个代码仓库内(同一个git),jenkins构建首先拉取代码,然后进行mvn compile时候,这些模块都拉取下来了,因此可以进行编译。如果dubbo api模块即hulk-api只是给自己的应用使用,那么不推送maven仓库也是可以的,但是我们的dubbo服务的作用就是为了给别人赋能,别人的项目git是不包含我们的hulk-api代码的,因此Jenkins构建时使用maven进行编译的必须要先下载hulk-api才可以。
方式1:在GitHub创建仓库,把本地项目和远程github仓库关联起来,然后把本地仓库推送到github即可,这个是常用做法,我一直以来也是这么做的。
方式2:菜单栏选择vcs->share project on github,最后点击share即可,如下图
这样在自己的github上就可以看见刚推送上去的仓库了。这种做法需要在idea配置好github的token。具体github token申请网上很多。
这种做法方便,不需要登录github。
添加内容如下,
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.1.7.RELEASE</version> <relativePath/> <!-- lookup parent from repository --> </parent>
内容如下,建议版本号都加这里
<properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <java.version>1.8</java.version> <skipTests>true</skipTests> <!--<docker.host>http://192.168.3.101:2375</docker.host> <docker.maven.plugin.version>1.1.0</docker.maven.plugin.version>--> <pagehelper-starter.version>1.2.10</pagehelper-starter.version> <pagehelper.version>5.1.8</pagehelper.version> <druid.version>1.1.10</druid.version> <hutool.version>4.5.7</hutool.version> <swagger2.version>2.9.2</swagger2.version> <swagger-models.version>1.6.0</swagger-models.version> <swagger-annotations.version>1.6.0</swagger-annotations.version> <mybatis-generator.version>1.3.7</mybatis-generator.version> <mybatis.version>3.4.6</mybatis.version> <mysql-connector.version>8.0.16</mysql-connector.version> <spring-data-commons.version>2.1.5.RELEASE</spring-data-commons.version> <jjwt.version>0.9.0</jjwt.version> <aliyun-oss.version>2.5.0</aliyun-oss.version> <logstash-logback.version>5.3</logstash-logback.version> <minio.version>3.0.10</minio.version> <guava.version>20.0</guava.version> <hulk-common.version>1.0-SNAPSHOT</hulk-common.version> <hulk-mapper.version>1.0-SNAPSHOT</hulk-mapper.version> </properties>
其它依赖声明也加这里
<dependencyManagement> <dependencies> <!--hulk通用模块--> <dependency> <groupId>org.zyj.hulk</groupId> <artifactId>hulk-common</artifactId> <version>${hulk-common.version}</version> </dependency> <!--hulk中MBG生成模块--> <dependency> <groupId>org.zyj.hulk</groupId> <artifactId>hulk-mbg</artifactId> <version>${hulk-mapper.version}</version> </dependency> <!--MyBatis分页插件starter--> <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper-spring-boot-starter</artifactId> <version>${pagehelper-starter.version}</version> </dependency> <!--MyBatis分页插件--> <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper</artifactId> <version>${pagehelper.version}</version> </dependency> <!--集成druid连接池--> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid-spring-boot-starter</artifactId> <version>${druid.version}</version> </dependency> <!--Hutool Java工具包--> <dependency> <groupId>cn.hutool</groupId> <artifactId>hutool-all</artifactId> <version>${hutool.version}</version> </dependency> <!--Swagger-UI API文档生产工具--> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>${swagger2.version}</version> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>${swagger2.version}</version> </dependency> <!--解决Swagger 2.9.2版本NumberFormatException--> <dependency> <groupId>io.swagger</groupId> <artifactId>swagger-models</artifactId> <version>${swagger-models.version}</version> </dependency> <dependency> <groupId>io.swagger</groupId> <artifactId>swagger-annotations</artifactId> <version>${swagger-annotations.version}</version> </dependency> <!-- MyBatis 生成器 --> <dependency> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-core</artifactId> <version>${mybatis-generator.version}</version> </dependency> <!-- MyBatis--> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>${mybatis.version}</version> </dependency> <!--Mysql数据库驱动--> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>${mysql-connector.version}</version> </dependency> <!--SpringData工具包--> <dependency> <groupId>org.springframework.data</groupId> <artifactId>spring-data-commons</artifactId> <version>${spring-data-commons.version}</version> </dependency> <!--JWT(Json Web Token)登录支持--> <dependency> <groupId>io.jsonwebtoken</groupId> <artifactId>jjwt</artifactId> <version>${jjwt.version}</version> </dependency> <!--统一Guava版本防止冲突--> <dependency> <groupId>com.google.guava</groupId> <artifactId>guava</artifactId> <version>${guava.version}</version> </dependency> </dependencies> </dependencyManagement>
父pom通常不加dependencies,如果要加,也只是加每个子模块都需要的dependencies。这里就涉及到dependencies和dependencyManagement的区别了
dependencyManagement应用场景
为了项目的正确运行,必须让所有的子模块使用依赖项的统一版本,必须确保应用的各个项目的依赖项和版本一致,才能保证测试的和发布的是相同的结果。在我们项目顶层的pom文件中,我们会看到dependencyManagement元素。通过它元素来管理jar包的版本,让子项目中引用一个依赖而不用显示的列出版本号。Maven会沿着父子层次向上走,直到找到一个拥有dependencyManagement元素的项目,然后它就会使用在这个dependencyManagement元素中指定的版本号。
这样做的好处:统一管理项目的版本号,确保应用的各个项目的依赖和版本一致,才能保证测试的和发布的是相同的成果,因此,在顶层pom中定义共同的依赖关系。同时可以避免在每个使用的子项目中都声明一个版本号,这样想升级或者切换到另一个版本时,只需要在父类容器里更新,不需要任何一个子项目的修改;如果某个子项目需要另外一个版本号时,只需要在dependencies中声明一个版本号即可。子类就会使用子类声明的版本号,不继承于父类版本号。
dependencies应用场景
相对于dependencyManagement,如果在父pom文件中中通过dependencies引入jar,将默认被所有的子模块继承。
子模块如果希望有自己个性化的内容,可以在子模块中对于其中的某个属性进重新定义。比如父pom声明了spring-web模块,版本是V3.2,如果子模块想使用V3.3,那么在子模块显式指定V3.3即可。
dependencyManagement与dependencies区别
dependencyManagement里只是声明依赖,并不实现引入,因此子项目需要显式的声明需要用的依赖。如果不在子项目中声明依赖,是不会从父项目中继承下来的;只有在子项目中写了该依赖项,并且没有指定具体版本,才会从父项目中继承该项,并且version和scope都读取自父pom;另外如果子项目中指定了版本号,那么会使用子项目中指定的jar版本。
dependencies即使在子模块中不写该依赖项,那么子模块仍然会从父项目中继承该依赖项(全部继承)。
在实际的项目开发中,推荐在父pom中使用dependencyManagement对项目中使用到的依赖包进行统一的管理。
dubbo api模块只是dubbo入参、出参以及定义的dubbo接口,实际并不需要依赖什么,当然这个模块要最小依赖,尽量少的依赖。
通常工具类和通用类放这个模块,比如apache工具包,hutool工具包等,依赖这些第三方工具类
<dependencies> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> </dependency> <dependency> <groupId>org.springframework.data</groupId> <artifactId>spring-data-commons</artifactId> </dependency> <dependency> <groupId>cn.hutool</groupId> <artifactId>hutool-all</artifactId> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> </dependency> </dependencies>
用于数据库交互,依赖数据库以及数据源,通常也会依赖hulk-common模块
<dependencies> <dependency> <groupId>org.zyj.hulk</groupId> <artifactId>hulk-common</artifactId> </dependency> <dependency> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-core</artifactId> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> </dependencies>
用于dubbo服务和业务服务,通常要依赖hulk-common和hulk-mapper,也依赖spring aop等,依赖dubbo。同时需要打包,要增加spring-boot-maven-plugin插件,内容大概如下
<dependencies> <dependency> <groupId>org.zyj.hulk</groupId> <artifactId>hulk-mapper</artifactId> </dependency> <dependency> <groupId>com.alibaba.boot</groupId> <artifactId>dubbo-spring-boot-starter</artifactId> <version>0.2.1.RELEASE</version> </dependency> <dependency> <groupId>io.minio</groupId> <artifactId>minio</artifactId> </dependency> <dependency> <groupId>com.ctrip.framework.apollo</groupId> <artifactId>apollo-client</artifactId> <version>1.7.0</version> </dependency> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build>
用于提供http功能,依赖spring mvc,依赖hulk-service(即也就依赖了hulk-common和hulk-mapper)
记录下使用idea快速创建maven多module,只有两个地方需要注意:
网上很多,随便参考。用户快速创建多模块的项目,必定创建项目再引入一系列依赖是很麻烦耗时的事情。