开始用GitHub已经有很长一段时间了,但是仅仅用来存储代码,也仅仅知道GitHub是基于Git的,却从未对Git进行过学习,很是惭愧。感谢思沃给了这个机会,而且给了很完整的参考资料,可以对Git有一个完整的了解。
Git简介
Git is a free and open source distributed version control system designed to handle everything from small to very large projects with speed and efficiency.
Git是一个免费开源的分布式版本控制系统,用来快速有效的的处理各种大小的项目。
版本控制系统:记录下所有文件的所有版本,可以有效地追踪文件的变化。当代码出错的时候,可以很容易地恢复到之前的状态。
发现一件很有意思的事情,Git官网logo旁边的话有五句,是随机出现的,充分表明了Git的理念和特点:
- --fast-version-control
- --everything-is-local
- --local-branching-on-the-cheap
- --distributed-is-the-new-centralized
- --distributed-even-if-your-workflow-isnt
集中版本控制
CVS及SVN都是集中式的版本控制系统,而Git是分布式版本控制系统。
集中式版本控制系统,版本库是集中存放在中央服务器的,一起工作的人需要用自己的电脑从服务器上同步更新或上传自己的修改。
但是,所有的版本数据都存在服务器上,用户的本地设备就只有自己以前所同步的版本,如果不连网的话,用户就看不到历史版本,也无法切换版本验证问题,或在不同分支工作。
而且,所有数据都保存在单一的服务器上,有很大的风险这个服务器会损坏,这样就会丢失所有的数据,当然可以定期备份。
分布式版本控制
那分布式版本控制系统与集中式版本控制系统有何不同呢?
分布式版本控制系统根本没有“中央服务器”,每个人的电脑上都是一个完整的版本库,不需要联网就可以工作。既然每个人电脑上都有一个完整的版本库,那多个人如何协作呢?比方说你和同事在各自电脑修改相同文件,这时,你们俩之间只需把各自的修改推送给对方,就可以互相看到对方的修改了。
分布式版本控制系统的安全性要高很多,因为每个人电脑里都有完整的版本库。大家之间可以相互复制。
分布式版本控制系统通常也有一台充当“中央服务器”的电脑,但这个服务器的作用仅仅是用来方便“交换”大家的修改,没有它大家也一样干活,只是交换修改不方便而已。
Git的三种状态
Git 和其他版本控制系统的主要差别在于,Git 只关心文件数据的整体是否发生变化,而大多数其他系统则只关心文件内容的具体差异。对于任何一个文件,在Git内都只有三种状态:已提交(committed),已修改(modified)和已暂存(staged)。已提交表示该文件已经被安全地保存在本地数据库 中了;已修改表示修改了某个文件,但还没有提交保存;已暂存表示把已修改的文件放在下次提交时要保存的清单中。由此我们看到 Git 管理项目时,文件流转的三个工作区域:Git 的工作目录,暂存区域,以及本地仓库。
Git特点
1.Git只关心文件的整体是否发生变化,而不关心文件的内容发不发生变化。变化文件的快照会被保存。 比如A文件被修改了,提交更新时,就会发现它被修改。(通过计算文件的sha-1值) A被修改,git就会对该文件做一个快照。并保存指向这次快照的索引。文件没有变化,那么Git不会保存。
2.几乎所有的操作都是在本地操作。
3.不可能你修改了文件,Git不知道。Git会根据文件或目录的结构计算出一个sha-1值。进行比对sha-1值的变化来看是否修改。
4.在Git中,只要提交了文件快照(也就是执行git add),就不用担心数据的丢失。
获取Git项目的仓库
第一种:自己创建git仓库
git init 初始化某个目录,表示用git进行管理
git add 对文件进行跟踪
git commit 对文件进行提交
第二种:
直接git clone,克隆现有的仓库