版本迭代控制(Not Git/svn)

码途霜焰狩
• 阅读 2311

版本迭代控制(Not Git/svn)

说到版本控制,大多数人的大脑中都一定会立刻想到 gitsvn 吧,只可惜,这次的主角可不是他们

虽说 git 和 svn 虽好,对于一些项目也能够进行很好的开发,但是呢,对于某些场景,还是有些 hold 不住的

比如,我们来举一个场景:

现在我们的源码大约有 500M,然后呢,采用的是分支开发,主干发布,但是呢,因为我们是提供中间层 service 的,迭代周期很短,对于一些特殊的客户,会时常有些特殊的逻辑处理,每个开发者可能会有好几个分支进行开发,这个样子的话,对于这些特殊逻辑,特殊版本的管理就非常的不方便,而且,因为每次都要拉出来一个分支,然后改动可能非常小,这就造成了非常大量的冗余量

于是,这个场景中,冗余量、大量迭代版本的管理,就上升到了我们的一个主要问题

如何解决呢?


单体代码库

在这里,我们引入一个节点(标签)的概念,先来说一下整体思路

现在,我们就抛弃 gitsvn 的思想,把所有的代码都放在一起,通过控制 节点粒度 来控制整体的冗余

首先,节点粒度我们先设定为以文件为单位,同时呢,约定我们的命名规范,文件名.节点标识.php,例如 Test.v1.php

接下来呢,就会有我们原始的版本,在这个原始的版本里面,所有的文件都是 base 节点

所有的文件都会有一个父节点,最终都是继承与 base 节点的

当我们需要迭代到 1.0.1 版本的时候,我们只要把需要改动的文件 copy 一个副本,然后按规范命名,接着只需对于这一个文件进行改动,这样,冗余的粒度就控制在了这个文件内

大大减少冗余的同时,还大大的提高了代码的复用,避免了菱形依赖,不同团队间的跨团队协作也变得更加灵活

接下来,我们怎么能够正常调用呢?

所以说,这种单体代码库需要一个路由引擎来驱动,这就要我们根据实际情况来实现了,可以直接根据节点表示来路由,也可以在中间加一层路由映射表,这就看具体需求了

同理,我们可以进一步调整节点粒度,来控制整体的冗余,比如,粒度细化到接口级别

~~~~~~ 萌萌哒的分割线 ~~~~~~~~~

好了,下面就来分析一下这种单体代码库的优劣

优点:

  • 统一版本控制

  • 广泛地代码共享和复用

  • 简化依赖管理,避免菱形依赖

  • 原子修改

  • 大规模重构

  • 跨团队协作

  • 灵活的团队边界和代码所有权

  • 代码可见性以及清晰的树形结构提供了隐含的团队命名空间

但是呢,随着代码量的增加,也会出现以下问题

  • 单体模型让代码结构更容易理解,但却让代码发现变得更困难

  • 开发人员需要能够查看代码库,找到相关程序库,并看看如何使用它们以及谁编写了它们。这就需要有代码搜索和代码浏览工具

  • 依赖重构和代码清理辅助工具,定期对无用代码进行清理

  • 版本管理的重心转移到了冗余控制上

所以说呢,对于管理,我们就需要开发一套额外的自动化工具了,比如说:

  • 代码库搜索工具:因为我们采用了单体代码库,所以慢慢的代码越来越多,代码搜索工具就变的必不可少了

  • 代码发现工具:也是为了维护代码库,定期发现清理无用代码

可能根据大家的实际情况,也需要一些其他的自动化工具


点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Jacquelyn38 Jacquelyn38
4年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Git基础考试题
Git:1.在windows上搭建git环境,成功后查看版本号Linux安装sudoaptgetinstallgityyuminstallgitywindows直接安装exe查看版本号:gitversion2.git与svn的区别(1)git是分布式的,svn是集中式的(2)git把内容按元数据的方式
Stella981 Stella981
3年前
IntelliJ IDEA(八) :git的使用
项目管理离不开版本控制,目前主流版本控制工具大概就是SVN和Git,至于两者有啥区别这里就不详细介绍了,如果有不明白的可以上网查资料,后期如果有机会我再开篇栏目细说,而且现在市场上Git的使用率已经远远高于SVN。我们在用IDEA开发项目的时候如何熟练使用Git来控制代码版本呢?一、安装Git使用Git当然需要先安装Git,安装过程就
Stella981 Stella981
3年前
GitHub和SVN的区别
GitHub和SVN的区别之前用的版本控制系统是SVN,但是最近因为流行使用GitHub,这篇文章认识一下Git和SVN的区别。1)Git是分布式的,SVN不是: 这是git和其它非分布式的版本控制系统,例如SVN,CVS等,最核心的区别。好处是跟其他同事不会有太多的冲突,自己写的代码放在自己电脑上
Stella981 Stella981
3年前
Git和GitHub的基本操作
GIT版本控制系统版本控制系统功能:1.记录版本历史信息(记录每一次修改的记录)2.方便团队之间相互协作开发3.远程开发......常用的版本控制系统cvs/svn:集中式分布系统git:分布式版本控制系统1.GIT工作原
Stella981 Stella981
3年前
Git基础命令篇
一、Git介绍(1)Git是一个开源(LinusTorvalds为了帮助管理Linux内核开发而开发)的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目,与常用的版本控制工具CVS,SVN等不同,它采用了分布式版本库的方式,不必服务器端软件支持。(2)Git的工作区、暂存区和版本库:工作区:就
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这
美凌格栋栋酱 美凌格栋栋酱
5个月前
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(
码途霜焰狩
码途霜焰狩
Lv1
愿得此身长报国,何须生入玉门关。
文章
4
粉丝
0
获赞
0