Git的诞生
很多人都知道,Linus在1991年创建了开源的Linux,从此,Linux系统不断发展,已经成为最大的服务器系统软件了。
Linus虽然创建了Linux,但Linux的壮大是靠全世界热心的志愿者参与的,这么多人在世界各地为Linux编写代码,那Linux的代码是如何管理的呢?
事实是,在2002年以前,世界各地的志愿者把源代码文件通过diff的方式发给Linus,然后由Linus本人通过手工方式合并代码!
你也许会想,为什么Linus不把Linux代码放到版本控制系统里呢?不是有CVS、SVN这些免费的版本控制系统吗?因为Linus坚定地反对CVS和SVN,这些集中式的版本控制系统不但速度慢,而且必须联网才能使用。有一些商用的版本控制系统,虽然比CVS、SVN好用,但那是付费的,和Linux的开源精神不符。
不过,到了2002年,Linux系统已经发展了十年了,代码库之大让Linus很难继续通过手工方式管理了,社区的弟兄们也对这种方式表达了强烈不满,于是Linus选择了一个商业的版本控制系统BitKeeper,BitKeeper的东家BitMover公司出于人道主义精神,授权Linux社区免费使用这个版本控制系统。
安定团结的大好局面在2005年就被打破了,原因是Linux社区牛人聚集,不免沾染了一些梁山好汉的江湖习气。开发Samba的Andrew试图破解BitKeeper的协议(这么干的其实也不只他一个),被BitMover公司发现了(监控工作做得不错!),于是BitMover公司怒了,要收回Linux社区的免费使用权。
Linus可以向BitMover公司道个歉,保证以后严格管教弟兄们,嗯,这是不可能的。实际情况是这样的:
Linus花了两周时间自己用C写了一个分布式版本控制系统,这就是Git!一个月之内,Linux系统的源码已经由Git管理了!牛是怎么定义的呢?大家可以体会一下。
Git迅速成为最流行的分布式版本控制系统,尤其是2008年,GitHub网站上线了,它为开源项目免费提供Git存储,无数开源项目开始迁移至GitHub,包括jQuery,PHP,Ruby等等。
历史就是这么偶然,如果不是当年BitMover公司威胁Linux社区,可能现在我们就没有免费而超级好用的Git了。
相关文章
- [Git] git代码统计
- [Git] Git fetch和git pull的区别
- git:Git fetch和git pull的区别, 解决Git报错:error: You have not concluded your merge (MERGE_HEAD exists).
- Git创建分支/GIT提交分支
- git使用简单指南
- [Git] A better git process
- [Practical Git] Configure global settings with git config
- [Practical Git] Clean up commits with git rebase
- [Git] Reflog
- Git远程06:push.default设置
- [Practical Git] Show who changed a line last with git blame
- [Practical Git] Navigate git command pager output with Unix less commands
- 详解Git工作区、暂存区、历史记录区以及git reset、git revert、git checkout等撤销命令的区别
- git恢复本地删除的文件夹取消增加的文件
- git命令之git clone用法
- Git:合并分支----git merge命令应用的三种情景
- 使用Jenkins配置Git和Maven的自动化构建
- Ubuntu Git安装与使用
- Git知识总览(四) git分支管理之rebase 以及 cherry-pick相关操作
- VsCode中好用的git源代码管理插件GitLens
- 一文吃透 VS Code+Git 操作(vs code中git的相关配置与使用)
- Git命令基础应用
- Git 报错fatal: not a git repository (or any parent up to mount point /) Stopping at filesystem bounda
- Git的fatal: Not a git repository (or any parent up to mount point /home)
- 【Git总结大全】git操作从入门到实战(总结篇)
- Pycharm中修改git提交代码的账户和用户名【Git追溯注解,git blame】
- Git实战之git客户端上传文件到github
- git中使用emacs和vimdiff/Ediff工具(三十一)
- 解决办法:git错误 error: failed to push some refs to 'https://github.com/...
- [Git & GitHub] 解决办法:Can’t connect to any repository : not authorized / not permitted