参考文档:

http://kyfxbl.iteye.com/blog/1680045
http://blog.csdn.net/wanghantong/article/details/36427411
http://my.oschina.net/lujianing/blog/354121

最近在整理公司软件项目工程结构,最初的设计模块间耦合度太高,过多的公共service与业务逻辑强相关。以至于后期要做集群系统的工作难以展开,于是这个时候选择重构是唯一的办法了。

很荣幸这个光荣而又艰巨的任务被老大交给我和另外一个有5年JAVA经验的“老司机”,由于之前没有干过重构这种高端大气的活,这次也是抱着打打酱油瞻仰学习的态度来的,想想还有点小激动。

可惜人算不如天算,跟我合作的搭档在接手2天后就辞职走人了,辞职的原因我是不得而知。但有个尴尬的问题就是:活谁干?这真令人绝望。。。

往事休要再提,反正又不是第一次被坑了,生活还得继续。

重构的第一项工作是要先整出来一个新的工程结构,这里简单记录下,使用maven构建项目框架的过程。

基础结构如下:

project
|--business (核心业务)
|--business-api
|--business-service
|--business-message
|--business-dao
|--business-web
|--common (公共组件、服务、常量)
|--common-component
|--common-component-...
|--common-service
|--common-constants
|--common-...
|--management (管理台)
|--management-...
|--taskserver (定时任务、批处理)
|--msgserver (消息队列)

模块定义:

  business是整个工程的核心模块,它提供了对各终端(iOS、Android、Web&PC)的所有服务。

  business-api作为核心服务的提供者,基本上所有的业务操作都由它来完成,以war工程独立运行。集群方式下可以多部署几个api,在前端做好负载均衡即可。

  business-service 和 business-dao(mapper&entity) 是api的具体实现,这2者以jar包的形式供api依赖调用。

  business-message里存放了对外的接口契约(intf)、请求(request)和响应体(response),以jar包发行,方便供第三方或其他业务模块调用。

  business-web是我们的前端服务器,主要完成渲染和呈现的功能。一些像报表这样轻业务的功能可以在这里独立完成。以war包形式发行,支持集群部署。

  common是公共组件部分,一些常量或第三方接入的工作可以在这里实现。

  management是管理台,主要提供一些对业务编排、配置的的功能。

  taskserver批处理或定时任务服务器,独立运行。

  msgserver消息队列服务器,主要用来协助核心服务模块完成一些异步调用的工作。如发短信、消息推送等功能。

创建maven工程:

先创建一个父工程project用来做项目聚合

创建business,这里选择maven module或者maven project都可以,只要类型是pom就可以。我喜欢平行结构这里选择maven project。大体步骤和上面雷同,唯独最后一步:

在business下面创建2个war和3个jar模块(maven module):

建立完成如下:

其他模块的建立过程跟这里大同小异,再次略过。

依赖关系:

众所周知maven的使用pom.xml来完成依赖管理,我们可以通过图形化或者直接修改pom.xml的方式完成配置。

添加依赖后生成的pom.xml如下:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.lichmama.project.business</groupId>
<artifactId>business</artifactId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<groupId>com.lichmama.project.business.api</groupId>
<artifactId>business-api</artifactId>
<packaging>war</packaging>
<dependencies>
<dependency>
<groupId>com.lichmama.project.business.service</groupId>
<artifactId>business-service</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>com.lichmama.project.business.dao</groupId>
<artifactId>business-dao</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>com.lichmama.project.business.message</groupId>
<artifactId>business-message</artifactId>
<version>0.0.1-SNAPSHOT</version>
</dependency>
</dependencies>
</project>

(未完待续。。。)

maven多模块项目聚合的更多相关文章

  1. IntelliJ IDEA中创建Web聚合项目(Maven多模块项目)

    Eclipse用多了,IntelliJ中创建Maven聚合项目可能有小伙伴还不太熟悉,我们今天就来看看. IntelliJ中创建普通的Java聚合项目相对来说比较容易,不会涉及到web操作,涉及到we ...

  2. 38.IntelliJ IDEA中创建Web聚合项目(Maven多模块项目)

    转自:https://blog.csdn.net/u012702547/article/details/77431765 Eclipse用多了,IntelliJ中创建Maven聚合项目可能有小伙伴还不 ...

  3. IntelliJ IDEA中创建Web聚合项目(Maven多模块项目)(转载)

    创建parent项目 1.打开IDEA,注意这里不要勾选模板,用模板创建过maven项目的小伙伴都知道模板创建项目非常慢,所以这里不要选模板,需要的文件夹我们后面自己来创建就可以了.所以这个页面直接点 ...

  4. SpringBoot+Maven多模块项目(创建、依赖、打包可执行jar包部署测试)完整流程

    一,创建Maven多模块项目先建立外层父工程         File →new →project  选择Spring Initializr          Next下一步到以下页面 工程结构如下 ...

  5. maven多模块项目构建

    描述 一个大的企业级项目通常跨越了数十万行代码,牵涉了数十或数百软件人员的努力.如果开发者在同一个项目下开   发,那么项目的管理.构建将会变得很难控制.因此设计人员会将项目划分为多个模块,多个模块独 ...

  6. Spring Boot 项目实战(一)Maven 多模块项目搭建

    一.前言 最近公司项目准备开始重构,框架选定为 Spring Boot ,本篇主要记录了在 IDEA 中搭建 Spring Boot Maven 多模块项目的过程. 二.软件及硬件环境 macOS S ...

  7. maven多模块项目,多web合并项目使用心得

    Fixflow,做中国最好的开源流程引擎!项目地址https://github.com/fixteam/fixflow 此文章适合maven初学者或想接触maven的用户,讲的只是皮毛,高手请自觉略过 ...

  8. Maven多模块项目搭建

    最近一直在思考如何能够更好的重用代码.减少重复劳动,之前有一篇文章通过导入JAR包的形式,可以重用部分形如util类的方法,但是这样的话,管理起来jar包,特别是协同工作,多项目情况下,管理JAR会出 ...

  9. SSM001/构建maven多模块项目

    一.Idea构建maven多模块项目 1.创建maven项目--创建父模块 [1].File->New->Module... [2].点击next,填写:GroupId,ArtifactI ...

随机推荐

  1. on方法使用注意事项

    on(eventType,[childSelector],[data],fn) 采用事件委托机制绑定事件,好处是子元素动态加入时无需再次绑定. on方法可以传入childSelector指定添加事件处 ...

  2. Combine Two Tables

    Table: Person +-------------+---------+ | Column Name | Type | +-------------+---------+ | PersonId ...

  3. OpenStack云平台的网络模式及其工作机制

    网络,是OpenStack的部署中最容易出问题的,也是其结构中难以理清的部分.经常收到关于OneStack部署网络方面问题和OpenStack网络结构问题的邮件.下面根据自己的理解,谈一谈OpenSt ...

  4. Win10 + Python + GPU版MXNet + VS2015 + RTools + R配置

    最近入手一台GTX 1070的笔记本,手痒想在win10上试下GPU跑模型,所以就有了接下来的安装GPU版mxnet的坎坷历程,经过多重试验终于搞定了python和R安装mxnet,现将主要点记录如下 ...

  5. React 读书笔记

    序言: 领导安排部门同事本月内看一本跟自己职业相关的书籍, 根基类的书籍已经看过了,重复阅读的意义不大,所以我平时看的都是视频,也许是视频作者没有出书的条件,也许是现在出书看的人越来越少了,也许有其他 ...

  6. (转)java匿名内部类详解

    原文:http://android.blog.51cto.com/268543/384844/   内部类是指在一个外部类的内部再定义一个类.类名不需要和文件夹相同. *内部类可以是静态static的 ...

  7. MVC4加载zTree树小控件

    前言: 第一次学习使用MVC框架,找了个练手项目,加载zTree树小控件.下面我就一步步说明我这次练手的经历以记录.如果有什么错误,希望各位大神帮忙指正,谢谢. 第一步: 利用VS2010新建一个MV ...

  8. java基础(十一章)

    一.理解什么是类和对象               万事万物皆对象 1.属性--对象具有的特征(特点) 2.方法--对象可执行的操作(能干什么事) 3.对象的定义: 是一个客观存在的,看的见或摸得着的 ...

  9. spring-boot+mybatis开发实战:如何在spring-boot中使用myabtis持久层框架

    前言: 本项目基于maven构建,使用mybatis-spring-boot作为spring-boot项目的持久层框架 spring-boot中使用mybatis持久层框架与原spring项目使用方式 ...

  10. 每天一个JS 小demo之留言板。主要知识点:DOM方法的理解和运用

    <!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"& ...