GIT初步


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远程仓库

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值