公共代码改为模块分版本管理

一、改为模块分版本管理原因

当A业务和B业务员相互依赖时,如果A业务重构,那么为了兼容需要保留新旧两份A业务代码,并且B业务需要加入兼容代码,当有很多这种需要保留两份代码+大量的兼容代码存在时,就会出现以下几个问题:
1. 冗长的代码难以阅读
2. 复杂的兼容逻辑往往带来极高的不稳定性
3. 维护起来会很麻烦,而且容易错误

二、如何改动

  1. 建立两个文件夹 trunkrelease
    • trunk:开发版本目录
    • release:包含所有版本的代码,可以根据需求选择不同的版本导出
      文件夹结构预览
  2. 每个单文件以及包模块增加 version 版本字段
  3. 每次修改代码时同步修改版本字段,用工具生成各模块之间的版本依赖关联文件
  4. 然后将新的代码保存到对应模块的新版本目录下。

三、如何使用

  • 使用 VersionManagement 工具。
    这里写图片描述
    1. 根据界面提示选择对应的数据
    2. 选择(二.3)中的关联文件即可生成你需要的版本
    3. 点击导出即可
    4. 如果你想自定义选择默写模块版本可以重左边模块树中选择
Maven项目管理工具,可以将一个完整的项目拆成一个一个模块进行开发,而一些比较通用的模块就可以作为公用组件。在其他项目中直接依赖使用,比如:公用的方法,权限组件等等。 一,新建一个简单的Maven工程,这个Maven工程只含一个pom文件,他是管理各个模块的父级POM,如: Xml代码 <packaging>pom</packaging> <modules> <module>app-utils</module> <module>app-dao</module> <module>app-service</module> <module>app-web</module> </modules> <packaging>pom</packaging> <modules> <module>app-utils</module> <module>app-dao</module> <module>app-service</module> <module>app-web</module> </modules> packaging节点只能指定为pom,modules节点说明由几个模块组合,上面是把我们经常使用的架构层模式成一个个组件进行开发dao->service->web层。此pom文档经常还被用来进行一些依赖管理和插件管理,特别对于团队依赖包的管理特别重要,如下: Xml代码 <dependencyManagement> <dependencies> <dependency> <groupId>javax.servlet</groupId> <artifactId>servlet-api</artifactId> <version>2.5</version> <scope>provided</scope> </dependency> <dependency> <groupId>javax.servlet.jsp</groupId> <artifactId>jsp-api</artifactId> <version>2.1</version> <scope>provided</scope> </dependency> </dependencies> lt;/dependencyManagement> <dependencyManagement> <dependencies> <dependency> <groupId>javax.servlet</groupId> <artifactId>servlet-api</artifactId> <version>2.5</version> <scope>provided</scope> </dependency> <dependency> <groupId>javax.servlet.jsp</groupId> <artifactId>jsp-api</artifactId> <version>2.1</version> <scope>provided</scope> </dependency> </dependencies> </dependencyManagement> Xml代码 <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <configuration> <source>1.6</source> <target>1.6</target> <encoding>UTF-8</encoding> </configuration> </plugin> </plugins> </build> <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <configuration> <source>1.6</source> <target>1.6</target> <encoding>UTF-8</encoding> </configuration> </plugin> </plugins> </build> 二、新建各个模块,这里可以在本项目中建,也可以在外部建立,这要看具体的项目,一般公用组件最好建立成外部新项目,这样对于新的项目也是可以直接依赖的。 如上面的app-utils公用组件通用工具类包:packaging节点是jar,如下: Xml代码 <parent> <artifactId>app-parent</artifactId> <groupId>com.hyq</groupId> <version>1.0-SNAPSHOT</version> </parent> <groupId>com.hyq</groupId> <artifactId>app-utils</artifactId> <version>1.0-SNAPSHOT</version> <parent> <artifactId>app-parent</artifactId> <groupId>com.hyq</groupId> <version>1.0-SNAPSHOT</version> </parent> <groupId>com.hyq</groupId> <artifactId>app-utils</artifactId> <version>1.0-SNAPSHOT</version> 注意:这里是需有parent节点的,说明是继承app-parent来的,其他跟普通的pom一样配置。 app-dao,app-service跟app-utils一样。而app-web,由于这个的package是war包,所以项目中必须含有web.xml,就是标准的web目录结构了。 注意:上面的一些组件,是需要运行insall命令才可以运行的:mvn clean install 在团队开发中,可以建立自己公司的web项目的父级pom项目,然后每个项目都把这个pom作为父级,有利于公司的统一依赖管理和插件管理
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值