谈谈maven多模块

记得在校的时候,通常用的比较多是动态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项目也打算采用这种开发方式。

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

转载于:https://www.cnblogs.com/youcong/p/9101961.html

1.[今日课程内容总览] Maven--***** 介绍 优点 用maven创建一个项目, 用maven创建一个ssm项目,每一层的代码开,把一个项目拆解成多个项目 2.[今日包含笔记] maven介绍: Eclise: 缺点: Jar包: 版本管理,解决jar包冲突:删除老的jar包,保留新的jar包 不同的项目,jar包要复制一份;Users Library 羡慕yum的好处,安装软件,自动下载,自动验证,自动安装,自动测试;镜像网站 Jar包的依赖: 致命的缺点:现象: 每一个项目都有前台(广大网民)和后台(管理员看的),后台的功能远远的大于>前台的功能;迭代升级;每次升级都要重启tomcat;将tomcat做很多个备份(10个),为了nginx转发;前台:访问比较大,管理员访问量比较小; 问题: 每次升级,10个tomcat都升级一次 后台的升级频繁要比前台频繁;升级10次,9次改的是后台的代码,只有一次是前台的代码 解决方案: 是将前台(广大网民看的页面)的代码和后台(管理员)的代码要开,将原来的一个项目别放到两个web项目;一个web项目一个tomcat;好处:更新的时候如果更新后台(管理员),只需要重启后台的tomcat(服务); 折成两个项目以后的缺点:Service以下的代码重复; 将Service层以下的代码放到一个新创建的java项目中,在部署的时候将Service(java项目)打成一个jar包,别放到两个web服务中;编译的时候让web项目依赖与Service(java项目)_source folder;配置麻烦,项目项目之间的依赖头脑得相当清晰 这个缺点Maven解决了; 请听今天的内容 拆前:图一 拆后是图二 3. 介绍 官网:http://maven.apache.org/download.cgi 目录介绍: Bin:二进制文件 Boot:引导,启动 Conf:配置文件 Lib:jar包 README.txt:读我 3.1.修改配置文件的内容 路径:%MAVEN_HOME%\conf\settings.xml 配置文件代码: d:/repo alimaven aliyun maven http://maven.aliyun.com/nexus/content/groups/public/ central 注意: 千万不要将文档中的setting的内容全部替换到maven中的内容,要对比着修改,保留原来的; 只修改本地仓库,和下载镜像(源) 3.2.Eclipse Maven的配置 每打开一个新的工作空间,要配置一下Maven,然后再写代码 3.3.创建Maven项目 右击创建一个maven project Packing:有三种: Jar:java项目, War:web项目 Pom:文件夹,jar和war文件,mavenProject:一个项目,可以放jar和war包,通过pom,一般新创建的maven Project是POM 3.4.创建一个Maven Model 最外面的项目MavenProject,其它的全部是Maven Model 3.4.1.创建JAR 目录介绍: Mvn-jar |-->Src:源码:java代码 |-->|-->main:代码:除测试以外的代码:junit |-->|-->main|-->java:代码 |-->|-->main|-->resources:配置文件 |-->|-->test:测试的代码,junit |-->|-->test|-->java:代码 |-->|-->test|-->resources:配置文件 |-->Target:编译后的文件 |-->|-->classes:代码编译后的class类 |-->|-->test-classes:测试类编译后的classes 3.4.2.创建WAR 目录介绍: Mvn-war |-->Src:源码:java代码 |-->|-->main:代码:除测试以外的代码:junit |-->|-->main|-->java:代码 |-->|-->main|-->resources:配置文件 |-->|-->main|-->webapp:webContent,一般放jsp,js,css |-->|-->test:测试的代码,junit |-->|-->test|-->java:代码 |-->|-->test|-->resources:配置文件 |-->Target:编译后的文件 |-->|-->classes:代码编译后的class类 |-->|-->test-classes:测试类编译后的classes |-->|-->m2e-wtp:编译后的web服务;war解压后的内容 创建war包以后报以下错误: 因为创建的web项目,webapps少了web-inf,web.xml 解决方案: 在项目上右击,Javaee Tools-->第二个选项 3.5.配置编译环境 将maven项目重新编译,在项目中右击,可以pom上右击,可以将pom(目录)下面的jar和war重新编译 如果出现以上情况,说明下载的jar包有问题,把这下面的文件删除,重新下载 每创建一个项目,都有pom.xml,所有的配置都在pom.xml中 网址:所有的groupId和artifactId到这个网站中找 http://mvnrepository.com/ Pom.xml:配置文件示例(含的编译环境) 4.0.0 com.bjsxt mvn 0.0.1-SNAPSHOT pom mvn mvn mvn-jar mvn-war org.apache.maven.plugins maven-surefire-plugin true org.apache.maven.plugins maven-compiler-plugin <!-- 3.6.1 --> 1.7 1.7 UTF-8 org.apache.maven.plugins maven-source-plugin true compile jar org.apache.maven.plugins maven-resources-plugin UTF-8 3.6.生命周期 Maven -build:javac;编译 Maven-install:java先编译,后运行 在项目的target中会生成jar包和war包, 在仓库中生成相应的目录,里面的放的是jar包和war包 Maven-clean:会把项目中的class文件和jar包war包删除 Maven-test:运行所的测试类,取决于位置,必须放到src/test下面;在运行的(install)跳过,运行的时候会执行一遍测试类(花的时间长) 4.创建一个标准的ssm项目 项目介绍: Ssm:项目的顶级目录 ssm_common:jar包,放的是原来src_common下面的代码 ssm_service:pom,文件夹,放了api和impl的项目 ssm_service_api:jar包,放的是所有Service的接口 ssm_service_impl:jar包,所有Service的实现类 ssm_service_back:管理员后台的web服务 ssm_service_head:前台的服务 凡是依赖:如果都是java项目,会将依赖的项目打成一个jar包放到classpath中, 如果是web项目,会将依赖的项目打成一个jar包,放到web-inf/lib中 特别的图 创建完以后如下图: 添加依赖 5.搭建ssm 5.1.创建数据库 5.2.创建项目:确定项目可以在tomcat上运行 5.3.添加Spring 添加jar包 添加JAR包 增加版本的常量 在不同的项目中可以使用不同的版本-这种情况不允许 添加配置文件 写测试代码 如下图: 结论: ~将原来的原始的项目,变成maven项目 ~相同的代码,不同的环境,将项目跑起来 5.4.添加Mybatis 将service折成了两个项目:service-api,和service-impl Service-api;放的是Controller层使用到的对象;Service的接口引用,Util,POJO, Service-impl:放的是调用Dao层的对象; 目前来看:我们的web服务都依赖了api服务和impl服务,在将来引用dubbo的时候,web服务只依赖api服务,不依赖Impl
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值