GIT初步

来源:互联网 发布:刷钻石软件 编辑:程序博客网 时间:2024/06/17 23:07


1. 内涵和外延

  1. 是一个开源分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目;
  2. 是Linus Torvalds为了帮助管理Linux内核开发而开发的一个开放源码的版本控制软件;
  3. 与常用的版本控制工具CVS, Subversion等不同,它采用了分布式版本库的方式,不必服务器端软件支持
  4. 不仅是版本控制系统,也是内容管理系统(CMS),工作管理系统等。
    注意
    1. “分布式”的特性指的是版本库的分布式,也就是说GIT可以在本地创建版本库(不像SVN不能提交版本到本地库)

2. GIT和SVN区别

  1. 核心区别 GIT是分布式的,SVN不是;
  2. 存储方式 GIT把内容按元数据方式存储,而SVN是按文件;
    1. 文件存储方式:所有的资源控制系统都是把文件的元信息隐藏在一个类似.svn,.cvs等的文件夹里。
  3. 分支 GIT分支和SVN的分支不同:分支在SVN中一点不特别,就是版本库中的另外的一个目录;
  4. GIT没有一个全局的版本号,而SVN有:目前为止这是跟SVN相比GIT缺少的最大的一个特征;
  5. 内容完整性 GIT的内容完整性要优于SVN:GIT的内容存储使用的是SHA-1哈希算法。这能确保代码内容的完整性,确保在遇到磁盘故障和网络问题时降低对版本库的破坏。

3. 安装和配置【略】

4. 工作流程【重点】

  1. 从远程版本库上克隆完整的GIT仓库(包括代码和版本信息)到本地;
  2. 在本地根据不同的开发目的,创建分支,修改代码
  3. 在本地自己创建的分支上提交代码;
  4. 在本地合并分支;
  5. 把远程版本库上最新版的代码fetch下来,然后跟自己的主分支合并;
  6. 如果没有主开发者,可以直接把代码push到远程版本库
  7. 生成补丁(patch),把补丁发送给主开发者;
  8. 看主开发者的反馈,如果主开发者发现两个一般开发者之间有冲突(他们之间可以合作解决的冲突),就会要求他们先解决冲突,然后再由其中一个人提交。如果主开发者可以自己解决,或者没有冲突,就通过;
  9. 一般开发者之间解决冲突的方法,开发者之间可以使用pull 命令解决冲突,解决完冲突之后再向主开发者提交补丁。
  10. 图例

5. 工作区、暂存区和版本库【重点】

- 工作区
  1. GIT仓库同级目录。
- 暂存区
  1. 一般存放在GIT目录下的index文件(.git/index)中,所以我们把暂存区有时也叫作索引(index
- 本地库
  1. 工作区有一个隐藏目录.git
    注意
    1. git add是把文件添加到暂存区(索引),需要进一步commit更新到本地版本库中;
    2. git reset HEADgit rm --cached<file>git checkoutgit checkout HEAD命令详细
    3. 解决冲突之后的文件直接commit的话,不会默认加入到暂存区(没有冲突的时候直接commit会默认把文件加入到暂存区),需要执行git add命令手动加入暂存区

6. 命令1

  1. git add
    1. 添加到暂存区/索引
  2. git fetch
    1. 下载远程版本库内容
  3. git merge
    1. 合并分支到当前分支
  4. git pull
    1. git fetch + git merge
  5. git reset HEAD
    1. 取消已经缓存的内容
  6. git status
    1. 查看需要添加到暂存区和已经添加到暂存区但是还没有提交的文件
      注意
      - GIT命令不区分大小写

7. 分支【GIT的“必杀技特性”】

  1. 合并不仅仅是简单的文件添加、移除的操作,也会合并修改(当在合并修改的时候出现冲突就要解决冲突);
  2. 其他
    1. 分支作用
      1. 使用分支意味着你可以从开发主线上分离开来,然后在不影响主线的同时继续工作。 即在没有合并之前,分支上的内容相互独立。
  3. 解决冲突【pull/fetch/merge-> 手动解决冲突(即冲突“三元素”直接包括的内容) -> git add -> git commit
    1. pull/fetch(从远程到本地)或者git merge(本地版本库之间合并,一般不会出现冲突),有可能出现冲突(会用<<<<<<HEAD======>>>>>local这三者标注冲突内容,详细见下面分析),那么就要手动解决,然后要git add告诉GIT冲突已经解决了(此时如果直接commit,会提醒有冲突要先解决才能commit普通没有冲突的文件如果过需要commit可以直接提交,这时候commit中包含了更新版本库,对于冲突文件必须要先添加到的索引中才可以commit))
    2. <<<<<HEAD======>>>>>local含义和作用
      1. <<<<HEAD(索引)和====之间代表索引里面指向的内容,而====>>>>local(本地)之间代表的则是本地内容

8. 远程仓库


  1. 如果你想通过GIT分享你的代码或者与其他开发人员合作,你就需要将数据放到一台其他开发人员能够连接的服务器上

注意
1. 为什么在clone Github上的仓库的时候要提供本地SSH
本地Git仓库和GitHub仓库之间的传输是通过SSH加密的
2. 可以使用公网服务器搭建自己的GIT远程仓库


  1. Git基本操作、Git查看提交历史、Git标签 ↩
0 0
原创粉丝点击