从0到1自建一个代码cr diff平台
小伙伴们有没有觉得学习数据库很有意思?有意思就对了!今天就给大家带来《从0到1自建一个代码cr diff平台》,以下内容将会涉及到MySQL、Node.js、javascript、git,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!
自建diff平台基于git(其他类似
首先明白diff平台是为了做什么,无非就是以下几个重点
- 应用发布卡点触发代码cr
- diff过程中的评论和留言和提交记录等信息的存储记录
- 如何更快更轻量级的实现分支diff
- 获取diff后如何将diff呈现给前端
- 点击diff文件后和“谁”比对,怎么比对和呈现
针对以上问题逐一进行分析和细化
一 应用发布卡点触发代码cr
首先要考虑什么时候你要触发这个diff,唯一确定的那肯定是发布流程中的发布前卡点,也就是说必须经过代码cr通过后才能进行下一步发布
graph TD A[构建打包] -->|卡点| B(代码review) -->|通过| C(发布)
还有一种情况就是是否要在日常开发过程中比如某个分支并不是需要走发布流程(例如技术优化等等),就需要单独给组员或者你的同事发diff评审
所以综上就需要有能触发diff的功能,其实就是将这个需要进行diff的分支仓库进行记录到数据库,返回对应id拼接成diff地址类似:http://diff.com/diffId?=111
然后剩下的工作就交给下一步(初始化diff)了
二 diff过程中的评论和留言和提交记录等信息的存储记录
这一步其实就是在考虑怎么设计数据库表了,存储信息其实很简单无非就是 1 git地址(用来初始化仓库比对diff)2 评论内容 3 发起diff的人信息 4 此分支的commmitlist(为什么要记录这个,因为可以从这里查看这个分支每一次的提交内容并且进行diff)
三 如何更快更轻量级的实现分支diff
这一步是重点,涉及到核心如何进行初始化diff给前端
首先细化一下这一步需要做的工作
- 从步骤一获取到的diff链接(已经存储了相关git信息和初始化了数据库信息),从diffId获取到的初始化信息有两个: 1 branch(需要进行diff的分支号) 2 git仓库地址
- 根据git仓库进行如下shell:(这个就不用赘述了,有点node基础的应该知道在nodejs中执行shell的操作)
`mkdir -p ${initCodeAddressDiff} && cd ${initCodeAddressDiff} && git init && git remote add origin ${gitAddress} && git fetch`
其中initCodeAddressDiff是在服务器上建立的此应用的分支文件目录,例如应用叫test,分支是0.0.1,那目录就是test/0.0.1,然后在这个目录下进行初始化git仓库(gitAddress)
- 上一步完成后就实现了可以进行git shell操作的文件容器了,下一步就是需要获取这个分支的diff信息了(注:此过程中省略了很多判空和容错校验,后续的shell都是在此文件目录下执行的):
`git fetch && git merge-base remotes/origin/master remotes/origin/${branch}`
这一步是做什么呢?是为了获取这个分支branch拉取出来那个时候的master祖先分支节点commit,后续的比对都是和这个节点进行diff,同时将这个commitId存入数据库,后续直接使用
- 获取此分支的所有未合并的commmitList
`git log remotes/origin/master..remotes/origin/${branchTag} --pretty=format:"%H^%an^%cn^%s^%cd"`
这是上面所说过的为了进行每一次提交的比对
- 开始进行真正的获取diff
`git fetch && git diff ${masterCommitId} ${branchTag} --stat-name-width=800 --stat-width=1000`
这段是为了获取diff内容,但是我还要知道更改了多少,是增删改的哪一类?例如:
index.jsx -------- +23,-2,M(这个文件是更改M,增加了23行删除了2行)
所以还需要执行下面的命令:
`git fetch && git diff ${masterCommitId} ${branchTag} --name-status`
最终组合后将diff文件渲染成tree树的结构返回给前端,这时候diff内容就已经好了
四 获取diff后如何将diff呈现给前端
- 将步骤三 的最后一步组合的信息返回给前端
点击diff文件后需要看到和祖先master的比对更改情况,这一步怎么实现呢?首先比如点击上一步说的index.jsx文件,那就需要将此文件对应拉取时候的masterCommitId节点的文件内容(oldFile)和这个分支0.0.1最新的文件内容(nowFile),并输出给前端,执行以下shell命令就可
git show ${commitId}:${filePath}
是不是很简单,这就获取到了对应commitId的filePath文件内容五 点击diff文件后和“谁”比对,怎么比对和呈现
之前都是和分支拉取时候那个节点的masterCommit进行比对,这样的话,如果主干分支进行了其他分支合并,那这些合并就不会体现在你的这个diff上面,所以还可以通过shell把最新的当前masterID获取一并返回给前端,这样用户就可以根据实际情况选择是比对祖先分支还是当前最新master
`git log remotes/origin/${branchTag} --pretty=format:"%H^%an^%cn^%s^%cd" -1`
下面就到了如何把两份文件进行比对了oldFile,nowFile,其实也很简单如果时间成本允许可以自行
npm diff进行自建渲染,图方便就直接使用比对类的开源库
import { MonacoDiffEditor } from 'react-monaco-editor';
到此整个实现方式就已经说完啦,希望大家都能严谨进行代码cr做到线上少出bug
这里再说下其中遇到的问题等:
- 使用node child_process.exec和child_process.spawn两个子进程的方式
- 评论信息如何通知给相应的人
- 如果点击了通过,此分支又有了新的提交那么就要重置这个为不通过
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于数据库的相关知识,也可关注golang学习网公众号。

- 上一篇
- GPL3.0许可证软件著作权纠纷案例解析 续一:VirtualApp还是不是开源软件?

- 下一篇
- sql查询数据总条数后怎么接收count(1)或者count(*)的值?
-
- 会撒娇的香菇
- 这篇技术贴太及时了,细节满满,很有用,已加入收藏夹了,关注作者大大了!希望作者大大能多写数据库相关的文章。
- 2023-01-30 07:28:57
-
- 欢呼的手机
- 太全面了,码住,感谢up主的这篇技术文章,我会继续支持!
- 2023-01-29 12:35:49
-
- 谨慎的钥匙
- 写的不错,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢师傅分享文章内容!
- 2023-01-29 02:54:26
-
- 数据库 · MySQL | 1小时前 |
- MySQL排序优化与性能提升技巧
- 153浏览 收藏
-
- 数据库 · MySQL | 3小时前 |
- MySQL中WHERE与HAVING的区别详解
- 340浏览 收藏
-
- 数据库 · MySQL | 8小时前 |
- MySQL排序优化与性能提升技巧
- 368浏览 收藏
-
- 数据库 · MySQL | 23小时前 |
- MySQL连接池配置与优化方法
- 297浏览 收藏
-
- 数据库 · MySQL | 23小时前 |
- MySQLGROUPBY使用技巧与常见问题
- 306浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL缓存优化技巧分享
- 392浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL安装到D盘教程及路径设置详解
- 279浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL缓存设置及查询作用解析
- 470浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQLcount优化技巧及性能提升方法
- 371浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQLUPDATE替换字段值方法详解
- 292浏览 收藏
-
- 数据库 · MySQL | 1天前 |
- MySQL基础:增删改查全教程
- 356浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 511次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 498次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 千音漫语
- 千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
- 95次使用
-
- MiniWork
- MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
- 89次使用
-
- NoCode
- NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
- 105次使用
-
- 达医智影
- 达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
- 98次使用
-
- 智慧芽Eureka
- 智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
- 97次使用
-
- golang MySQL实现对数据库表存储获取操作示例
- 2022-12-22 499浏览
-
- 搞一个自娱自乐的博客(二) 架构搭建
- 2023-02-16 244浏览
-
- B-Tree、B+Tree以及B-link Tree
- 2023-01-19 235浏览
-
- mysql面试题
- 2023-01-17 157浏览
-
- MySQL数据表简单查询
- 2023-01-10 101浏览