一、版本控制系统
1、集中式版本控制系统
数据都保存在中央服务器,SVN就是典型的集中式版本控制系统。
2、分布式版本控制系统
各个节点都保存了完整的数据,Git是目前最优秀的分布式版本控制系统。
2、Git与SVN的区别
- SVN保存变化的内容。
- Git是一个文件系统,存储了文件的完整拷贝:即保存每一次变化的文件,未变化的文件只保存上一个版本的指针。
3、工作区、暂存区、本地仓库、远程仓库
3、暂存区/index
index是二进制文件,查看暂存区的内容:
git ls-files --stage
index是一个文件列表,列表名由hash值 + 文件名构成
4、Git结构
Git保存文件的最基本的对象是blob对象,Git本质上只是一棵巨大的文件树,树的每一个节点就是blob对象
1、commit对象
Git
1、文件对象、树对象和提交对象
文件对象(blob object):文件内容;
树对象(tree object):文件结构、文件目录;
提交对象(commit object):顶层树对象(hash值)、附加信息(作者/提交者信息、时间戳)、父提交对象(上一次提交信息)。
注意
1、 Git保存文件的完整内容,不保存差量变化,即文件每变化一次,就会生成新的文件拷贝,而相同的文件只有一个拷贝;
2、Git版本控制的核心是维持文件树的状态;
3、SHA-1 校验和是文件的指针,Git依靠它来区分文件。
常见命令
1、初始化
git init [test]
2、添加
git add file
3、提交
git commit -m "备注"
4、更新远程仓库
git push
5、创建本地分支
git branch dev
6、创建远程分支
git push --set-upstream origin dev1