痞子衡嵌入式:备受开源社区推崇的分布式版本控制工具(Git)
大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家介绍的是分布式版本控制工具Git。
1.为什么需要版本控制系统?
单人软件项目开发过程,往往很多功能都是逐步增加的,在代码开发过程中,有的时候功能并不是单向递增的,中途可能会经过不断地优化设计与修改,而修改的过程中有时会出现误操作导致功能缺陷,当时并没有及时发现,等出问题时,这时候免不了要回过头来查找问题,定位问题最常用的办法就是查看自己曾经到底修改了哪里,此时便涉及到一个概念叫“版本控制”,显然我们需要一个工具能记录开发过程中的所有版本,并能够在需要的时候能切换到任意指定的版本。
随著软件项目规模越来越大,多人协作开发已成为不可避免的趋势,每个成员都在本地修改,添加,删除项目里的功能,当把每个人的工作汇总起来时,麻烦就出现了,到底是改了哪些功能?功能里的哪些细节被修改了?功能的修改出现冲突怎么办?此时功能汇总合并工作便变得非常低效,汇总完成后还需要再将代码同步到每个项目成员本地。此时便涉及到另外一个概念叫“版本库”,版本库就是一个有着自定义数据结构的仓库,进入仓库的东西都按照统一结构存放着,版本库用来记录整个项目的功能是如何一步步演化的。显然版本库使得团队协同开发变得简单。
总结一下,版本控制系统=版本库+版本管理工具。版本控制系统使得项目开发变得更加高效。
2.版本控制系统Git由来
版本控制系统有很多,比如CVS、SVN、Mercurial、Git,其中Git是一个概念非常先进的完全分布式版本控制系统。
Git诞生2005年,其创始人叫Linus Torvalds,什么?没听到这位仁兄?如果你知道Linux系统的话,没错,这位仁兄也是Linux内核发明人。
Git设计的初衷是为了管理Linux系统源码,Linus于1991年创建了开源的Linux,世界各地Linux社区的人都在为Linux编写代码,那Linux的代码是如何管理的呢?实际上,在2002年之前,Linux代码合并工作完全是Linus手工完成的。到了2002年,Linux代码库之大让Linus很难继续通过手工方式管理了,Linus迫于压力只得选择一款叫BitKeeper的商业版本控制系统,到了2005年,Linux社区有人试图破解BitKeeper协议,但被BitMover公司及时发现了,BitMover一怒之下收回了Linux社区使用权。于是Linus花了两周时间用C写了一个分布式版本控制系统,这便是Git!之后一个月,Linux系统的源码开始由Git管理了!
自那以后,Git迅速成为最流行的分布式版本控制系统,尤其是2008年,GitHub网站上线了,它为开源项目免费提供Git存储,无数开源项目开始迁移至GitHub,包括jQuery,PHP,Ruby等等。
3.Git主要有哪些特点?
Git是一款免费的、开源的、分布式的版本控制系统。Git主要有以下4大特点:
- 速度极快:Git在本地保存着所有当前项目的历史更新,所以处理起来速度飞快。
- 省心可靠:Git可以时刻保持数据完整性,多数操作仅是添加数据,一旦提交快照之后就完全不用担心丢失数据。
- 离线工作:Git近乎所有操作都是本地执行,绝大多数操作都只需要访问本地文件和资源,不用连网。
- 资源丰富:越来越多的公司,开源项目使用Git,包括Ruby On Rails,jQuery,Perl,Debian,Linux Kernel等等。拥有一个强大的社区是很大的优势,有很多教程、工具。
4.三种常见的Git开发流程
Git是分布式管理方式,它与集中式管理方式最大的区别是Git支持本地提交,因为每个开发者本地都有服务器的完整数据库。当需要将本地提交同步到公共服务器上的数据库时,就出现了以下三种开发模式来规范这种同步行为。
第一种模式叫平等合作模式,这种模式下没有明确的项目负责人,每个人对项目的控制权平等。每个开发都可以对项目进行任意修改。
![](http://henjay724.com/image/cnblogs/Git_Process_Freestyle_Mode.jpg)
第二种模式叫经典开发模式,这种模式下明确了一个项目负责人,由这个负责人汇总所有开发人员的提交,并负责对项目进行统一修改。
![](http://henjay724.com/image/cnblogs/Git_Process_Free_Mode.jpg)
第三种模式叫超大项目模式,这种模式下有二级经典开发模式,即将项目分成多个子模块,每个子模块均有自己的公共服务器,每个子模块的开发使用经典开发模式,而子模块的汇总也是经典开发模式。
![](http://henjay724.com/image/cnblogs/Git_Process_Project_Mode.jpg)
Git的世界还有很多好玩的东西,具体我们下篇再说。
至此,分布式版本控制工具Git基本知识痞子衡便介绍完毕了,掌声在哪里~~~
参考资料:
[1]. Git简介
[2]. Git浅显易懂教程
[3]. 迁移到Git的八个理由
[4]. Git的主要特点
[5]. git使用简介
欢迎订阅
文章会同时发布到我的 博客园主页、CSDN主页、微信公众号 平台上。
微信搜索"痞子衡嵌入式"或者扫描下面二维码,就可以在手机上第一时间看了哦。
相关文章
- [git] log中Merge branch 'master' of xxx的产生原因
- [Linux] nacos配置中心curl发布和获取服务以及配置
- [linux] Windows 10 家庭版安装wsl ubuntu子系统
- [GIT] git打标签tag和分支branch的区别
- [linux] 使用curl排查接口问题
- [linux] 查看所有的系统用户
- [git] git中origin的含义
- [git] 打标签命令
- [git] git clone指定分支代码
- [git]git中分支的概念
- [Go] gin 解决: accept4: too many open files
- [Linux] 网络抓包工具tshark
- [Git[ 解决 git branch -M main error: refname refs/heads/master not found
- [Linux] ps+awk +while 实时查看进程内存占用情况
- 【架构师(第四十五篇)】 服务端开发之认识 Github actions
- 为Linux手动安装Mcsmanager
- git 常用命令小记
- Go语言逆向技术:恢复函数名称算法
- 嵌入式:ARM处理器的工作状态
- MySQL基础知识(二)-超详细 Linux安装MySQL5.7完整版教程及遇到的坑