记得在校的时候,通常用的比较多是动态web工程,动态web工程导入最多就是jar包,这些jar包需要自己手动复制粘贴放入lib目录下,然后build path,有的IDE会自动build path有的需要手动选中所有lib,然后build path。

后来工作了,用的最多的就是maven。maven简单的说,它就是项目构建工具,你需要什么依赖,就去maven库中搜索,然后找到你想要的依赖,将其复制到你的pom.xml文件中,注意用<dependencies></dependencies>将依赖进行包含。

为什么用maven?

给我感触最深的就是之前用动态web工程构建项目,光导jar包就花了不少时间,我经常强调一句,jar包导对,你的项目基本成功了80%。这个项目指的是框架整合。如果导不对,错误都不好找。

而maven,只需将找到的依赖放入pom.xml文件中,就会自动去下载这些依赖,当然maven仓库最初是没有任何依赖。

我用的是eclipse 氧气版,自带maven插件,大家可以去Eclipse官网去下载 https://www.eclipse.org/downloads/  另外idea也自带maven插件,虽然idea我几乎没用过,用的特别少,除了之前帮助一位朋友解决一些项目问题时,用过,其他时候用的最多的还是eclipse。

不说太多题外话,用maven最直接的原因就是不用为jar包发愁。

还有为什么用maven?

让项目结构更清晰规范,而且还更易扩展,动态web构建项目,扩展太不易了,特别是针对电商,金融一些大型网站而言。

对于maven而言用多模块开发更好,比较符合解耦原则。

这个是我很久之前创建的一个maven项目,这里就不以动态web项目为例了。

这个maven项目并没有多模块,所以我从dao到service,乃至controller,或者以后加入redis或者集成第三方插件都要在这个项目下写。

对于个人开发而言,这倒影响不大,但是假设它是一个大规模后台系统,多人进行开发,全部都在这一个项目下开发,即便使用git等版本控制工具进行代码管理,使用git是为了让代码管理的更好,同时也是为了方便合并代码比对。

早期团队三四个开发一个项目还好,后来走了一部分人,来了几个新手,新手的话,对代码逻辑不是特别清楚,所以要一一细看,但是如果是如下所示:

一共11个包,每个包至少有十几二十个java类,但真实开发场景中,不只11个包,特别是对于一些大型系统而言,三四十个包,假设三四十个包全部混合在一个项目下,每个包下至少三十个java类,对于新手而言熟悉代码需要比较长的时间,这就增加了一定的成本。

说到这,maven多模块就可以解决这个问题,还是以我的博客为例:

下面是maven多模块构建项目:

总共五个项目,一个父工程,四个子工程。

父工程主要装载着主要的依赖文件

子工程分别有:

blog-common:主要放公共复用的类,例如常用工具类等

blog-core:主要放入核心类,例如aop,shiro或者redis等,当然也包括项目的主要核心代码

blog-generator:代码生成器

blog-web:controller常用放置地,包含相关的配置文件,同时也可包含代码生成器生成的代码

目前只有这几个,但是大家试想,如果我要接入很多第三插件或者其他应用项目,我只需增加子工程即可

而且我研究过ibase4j,jeesite,guns等github上的开源项目,他们的项目构建大多如此。

比如ibase4j,它是将项目分成这样:

简单的说根据业务进行模块分层

根据业务模块分层也是maven构建多模块项目常用的做法之一。

从中也可以看出多模块真的符合解耦原则,常规的maven工程之所以不解耦是因为全部放置在一个工程里,非常不符合解耦。

代码耦合性重,只会增加开发成本,降低效率,多模块构建项目,让业务更加清晰,更加规范,非常有利于项目开发效率。

我最近公司项目就使用这个,同时我个人的blog项目也打算采用这种开发方式。

今天只是浅谈,一时灵感,让我忍不住想要分享。大家针对该随笔有更好的意见和想法,欢迎分享

谈谈maven多模块的更多相关文章

  1. Maven多模块,Dubbo分布式服务框架,SpringMVC,前后端分离项目,基础搭建,搭建过程出现的问题

    现互联网公司后端架构常用到Spring+SpringMVC+MyBatis,通过Maven来构建.通过学习,我已经掌握了基本的搭建过程,写下基础文章为而后的深入学习奠定基础. 首先说一下这篇文章的主要 ...

  2. [转]Maven 划分模块

    所有用Maven管理的真实的项目都应该是分模块的,每个模块都对应着一个pom.xml.它们之间通过继承和聚合(也称作多模块,multi-module)相互关联.那么,为什么要这么做呢?我们明明在开发一 ...

  3. IntelliJ Idea14 创建Maven多模块项目

    Maven多模块项目的参考资料 Sonatype上的教程 http://books.sonatype.com/mvnex-book/reference/multimodule.html 在这个教程里, ...

  4. [置顶] Maven多模块项目 eclipse热部署 Maven项目实现 tomcat热部署 二

    最近看到有好多童鞋比较热衷热部署,特别是多模块的项目,其实这热部署如果多模块比较大资源,容易内存溢出或者电脑卡住,并不建议这么做. 不过了解下也没有关系,这里我就在说说热部署的另外一种方法,因为我之前 ...

  5. Maven入门,Maven项目的创建,nexus 2.x搭建私服以及Maven多模块项目创建

    maven的了解做一个总结,以便日后查阅, 若有不足之处,还望指出,学无止境 当然也能起到入门效果. 一,搭建maven私服 1.工具 a. Nexus 2.5.1-01 b. Maven 3.3.9 ...

  6. eclipse导入SVN上的Maven多模块项目

    eclipse导入SVN上的Maven多模块项目 博客分类: Eclipse&MyEclipse SVN Maven   一.SVN上Maven多模块项目结构 使用eclipse导入SVN上的 ...

  7. Maven多模块的开发项目搭建

    系统越复杂,所有的业务逻辑都放在一个项目里,各个包之间的业务逻辑相互调用,这样添加了开发成本,同时对之后的系统维护,错误排查带来一定的麻烦. 通过Maven的多模块开发,把一个系统拆分成多个模块,通过 ...

  8. Maven分模块以及打war包

    我们如何进行模块化开发呢? 我们使用上面的例子进行演示,先进行合理的优化,我们希望dao和service作为通用的底层工具来使用,把它们合并成一个核心模块(core),build成core.jar,简 ...

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

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

随机推荐

  1. 【Java并发编程】20、DelayQueue实现订单的定时取消

    当订单定时取消需要修改数据库订单状态,但是怎么确定订单什么时候应该改变状态,解决方案有下面两种: 第一种,写个定时器去每分钟扫描数据库,这样更新及时,但是如果数据库数据量大的话,会对数据库造成很大的压 ...

  2. 设计模式之状态模式(State )

    状态模式是根据其状态变化来改变对象的行为,允许对象根据内部状态来实现不同的行为.内容类可以具有大量的内部状态,每当调用实现时,就委托给状态类进行处理. 作用 当一个对象的内在状态改变时允许改变其行为, ...

  3. Dockerfile 中 RUN, CMD, ENTRYPOINT 的区别

    RUN 指令:用于指定 docker build 过程中要运行的命令. 语法格式: RUN <command> 或 RUN ["<executeable>" ...

  4. mysql 5.7 线程阻塞处理

    出现的错误: ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction 解决办法: 查看sleep的进程 m ...

  5. imooc《JavaScript深入浅出》上的一个 arraysSimilar 函数

    任务 请在 index.html 文件中,编写 arraysSimilar 函数,实现判断传入的两个数组是否相似.具体需求: 数组中的成员类型相同,顺序可以不同.例如 [1, true] 与 [fal ...

  6. JS的一些小知识

    1.     0.1+0.2==0.3? 结果为false 原因:由于计算机是用二进制来存储和处理数据数字,不能精确表示浮点数,而JavaScript是一种弱类型语言,没有相应的封装类来处理浮点数运算 ...

  7. MSys2安装QT5

    1. MSYS2 shell # pacman –Syuu 2. Reopen MSYS2 # pacman –Syuu 3.添加国内源 msys64\etc\pacman.d 目录下有三个文件 1. ...

  8. python自动化开发-7

    socket编程 Socket是应用层与TCP/IP协议族通信的中间软件抽象层,它是一组接口.在设计模式中,Socket其实就是一个门面模式,它把复杂的TCP/IP协议族隐藏在Socket接口后面,对 ...

  9. 在Visualforce页面中使用Visual Flow

    在本文中,我们将通过一个示例说明如何将"流"(Visual Flow)用于Visualforce页面. 更全面的知识可以参考官方文档. 创建流 我们要创建一个流,它的作用是得到一个 ...

  10. Git 恢复本地误删的文件

    通过git进行代码管理的项目,如果在本地编辑的过程中误删了某些文件或者文件夹,可以通过git操作来复原. Step 1: git status 查看本地对改动的暂存记录.如下图所示,本人误删了文件夹“ ...