摘要:说到版本控制,大多数人的大脑中都一定会立刻想到和吧,只可惜,这次的主角可不是他们虽说和虽好,对于一些项目也能够进行很好的开发,但是呢,对于某些场景,还是有些不住的比如,我们来举一个场景现在我们的源码大约有,然后呢,采用的是分支开发,主干发布
说到版本控制,大多数人的大脑中都一定会立刻想到 git 和 svn 吧,只可惜,这次的主角可不是他们
虽说 git 和 svn 虽好,对于一些项目也能够进行很好的开发,但是呢,对于某些场景,还是有些 hold 不住的
比如,我们来举一个场景:
现在我们的源码大约有 500M,然后呢,采用的是分支开发,主干发布,但是呢,因为我们是提供中间层 service 的,迭代周期很短,对于一些特殊的客户,会时常有些特殊的逻辑处理,每个开发者可能会有好几个分支进行开发,这个样子的话,对于这些特殊逻辑,特殊版本的管理就非常的不方便,而且,因为每次都要拉出来一个分支,然后改动可能非常小,这就造成了非常大量的冗余量
于是,这个场景中,冗余量、大量迭代版本的管理,就上升到了我们的一个主要问题
如何解决呢?
在这里,我们引入一个节点(标签)的概念,先来说一下整体思路
现在,我们就抛弃 git 和 svn 的思想,把所有的代码都放在一起,通过控制 节点粒度 来控制整体的冗余
首先,节点粒度我们先设定为以文件为单位,同时呢,约定我们的命名规范,文件名.节点标识.php,例如 Test.v1.php
接下来呢,就会有我们原始的版本,在这个原始的版本里面,所有的文件都是 base 节点
所有的文件都会有一个父节点,最终都是继承与 base 节点的
当我们需要迭代到 1.0.1 版本的时候,我们只要把需要改动的文件 copy 一个副本,然后按规范命名,接着只需对于这一个文件进行改动,这样,冗余的粒度就控制在了这个文件内
大大减少冗余的同时,还大大的提高了代码的复用,避免了菱形依赖,不同团队间的跨团队协作也变得更加灵活
接下来,我们怎么能够正常调用呢?
所以说,这种单体代码库需要一个路由引擎来驱动,这就要我们根据实际情况来实现了,可以直接根据节点表示来路由,也可以在中间加一层路由映射表,这就看具体需求了
同理,我们可以进一步调整节点粒度,来控制整体的冗余,比如,粒度细化到接口级别
~~~~~~ 萌萌哒的分割线 ~~~~~~~~~
好了,下面就来分析一下这种单体代码库的优劣
优点:
统一版本控制
广泛地代码共享和复用
简化依赖管理,避免菱形依赖
原子修改
大规模重构
跨团队协作
灵活的团队边界和代码所有权
代码可见性以及清晰的树形结构提供了隐含的团队命名空间
但是呢,随着代码量的增加,也会出现以下问题:
单体模型让代码结构更容易理解,但却让代码发现变得更困难
开发人员需要能够查看代码库,找到相关程序库,并看看如何使用它们以及谁编写了它们。这就需要有代码搜索和代码浏览工具
依赖重构和代码清理辅助工具,定期对无用代码进行清理
版本管理的重心转移到了冗余控制上
所以说呢,对于管理,我们就需要开发一套额外的自动化工具了,比如说:
代码库搜索工具:因为我们采用了单体代码库,所以慢慢的代码越来越多,代码搜索工具就变的必不可少了
代码发现工具:也是为了维护代码库,定期发现清理无用代码
可能根据大家的实际情况,也需要一些其他的自动化工具
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/21945.html
摘要:项目地址瓦力,上线开源两个月,目前已支持超过十家企业线上部署使用,每周更新一个版本,持续带来新特性。支持开放接口支持第三方了解更多项目地址瓦力,官方主页瓦力。 1 Git Flow 一般而言,软件开发模型有常见的瀑布模型、迭代开发模型、以及最近出现的敏捷开发模型等不同的模型。每种模型有各自应用场景,Git Flow是构建在Git之上的一个组织软件开发活动的模型,Git Flow重点解...
摘要:文本已收录至我的仓库,欢迎不知道大家还是学生的时候有没有这个问题公司做的项目和自己在学校练手的项目有多大的区别。总的来说,我实习的总时间也快半年了,谈谈我觉得公司项目和自己练手的项目有啥区别,欢迎补充。 前言 只有光头才能变强。文本已收录至我的GitHub仓库,欢迎Star:https://github.com/ZhongFuCheng3y/3y 不知道大家还是学生的时候有没有这个问...
阅读 2861·2021-11-24 09:39
阅读 1113·2021-11-02 14:38
阅读 4036·2021-09-10 11:26
阅读 2712·2021-08-25 09:40
阅读 2270·2019-08-30 15:54
阅读 447·2019-08-30 10:56
阅读 2693·2019-08-26 12:14
阅读 3182·2019-08-26 12:13