Git起步

Git起步

版本控制

分布式版本控制系统(Distributed Version Control System, 简称DVCS)。诸如Git,Mercurial、Bazaar还有Darcs等这类系统中,客户端不只提取最新的版本的文件快照,而是把原始的代码仓库完整地镜像下来。

Git基础要点

直接快照,而非比较差异

Git并不保存更改前后的差异数据,而是对变化的文件做快照后(其他版本控制器记录的是deltaFile,而Git记录的时File1,File2...。),记录在一个微型的文件系统中。然后建立指向每个快照的索引。如果文件没有更改,那么引用上一次的快照的索引。

近乎所有操作都可本地执行

时刻保持数据完整性

Git使用SHA-1算法计算数据的Checksum,通过文件的内容和目录的结构计算出一个SHA-1哈希值,作为指纹字符串。所以如果文件在传输时变得不完整,或者磁盘损坏导致文件数据缺失,Git都恩那个立即擦觉。

多数操作仅添加数据

Git内文件的三种状态

  • 已提交(committed),文件已经安全地保存到本地数据库中;
  • 已修改(modified),文件已修改,还未提交保存;
  • 已暂存(staged),把已修改的文件放在下次提交时要保存的清单中。

文件流转的三个工作区域:

  • Git的本地数据目录(git directory,repository)
  • 暂存区(staging area)
  • 工作目录(working directory)
    基本的Git工作流程:
    1. 从repository中checkout某个版本的;
    2. 在工作目录中修改默写文件;
    3. 对这些修改了的文件作快照,并保存到暂存区;
    4. 提交更新,将保存在暂存区域的文件快照转存到git目录中。

初次运行Git前的配置

git config工具(实际是git-config命令)专门用来配置货读取相应的工作环境变量。这些变量存于如下配置文件中:

Git中配置文件的三个目录

  • /etc/gitconfig,对所有用户适用的配置。git config使用--system选项来选取该配置;
  • ~/.gitconfig,只对当前用户适用的配置。git config使用--global选项来读取该配置;
  • ./.git/config,当前项目的git目录中的配置文件,仅针对当前项目有效。git config时无选项就是选择该配置。

配置文件按照局部优先的原则来生效,也就是每一级别的配置都会覆盖上层的同名变量的配置。

配置信息

  • 用户信息,包含user名字和e-mail两个信息
  • 文本编辑器,Git需要你输入一些额外信息时调用的编辑器,默认使用操作系统指定的编辑器。
  • 差异分析工具,Git支持kdiff3,tkdiff,meld,xxdiff,vimdiff,gvimdiff,ecmerge和opendiff等合并工具的输出信息。

查看配置信息

使用git config --list来列出已有的配置信息。

查看帮助

查看git的各种工具使用帮助,三种方法:

  
  
  
  
  1. $git help <verb>
  2. $git <verb> help
  3. $man git-<verb>

例如查看如何使用config,运行:$git help config

你可能感兴趣的:(Git起步)