第一章 起步

1.关于版本控制

版本控制用于记录和追踪目录结构和文件内容变化,能够追溯过去的任何修改和变化,并恢复到任何历史状态。

版本控制系统可以按照发展过程分成以下几类:

  • 目录备份。记录版本变化最简单的方法就是复制项目,根据目录名字区分不同版本或时间点。
  • 本地版本控制系统。每次都备份完整的目录,在多个版本目录中就会存在很多份完全一样的冗余文件,为了解决这个问题,又出现了将不同版本的差异保存成补丁的本地版本控制系统,如比较流行rcs命令。
  • 集中化的版本控制系统。本地版本控制系统还是不便于多人协同工作,集中化的版本控制系统(CVS,Subverison,Perforce等)进一步解决了这个问题。集中化版本控制系统将版本数据都保存在服务器上,参与者通过客户端连接到服务器获取版本数据或者提交修改。

  • 分布式版本控制系统。集中式版本控制系统在无法通过网络连接版本库服务器的情况下,提交修改等很多功能都无法执行,中心版本库故障会影响所有参与者并且有丢失数据的风险。分布式版本控制系统(如Git,Mercurial,Bazaar,Darcs等)在客户端会保存完整的版本库备份,可以同时与多个远程版本库协作,并且除同步版本库外的所有操作都在本地执行。

2.Git的历史

2005年,Linux内核开源社区为了更好的管理Linux项目自主开发的版本控制系统。

3.Git的特点

Git的跟svn在概念上有很大的差别,相互比拟反而更容易混淆命令的实际意义。

  • 直接存储文件快照(特定时间点的完整文件),而非存储差异

  传统的版本控制系统通过逐行比较内容差异来确定数据是否变化,提取并保存差异。Git不关心差异,直接比较整个文件先前和此刻内容的校验值(即40位SHA1值)来确定是否修改,如果有修改会将整个文件保存到版本库数据目录中,并通过该SHA1值查找和访问版本库中的数据对象。

  • 几乎所有操作都在本地执行,只有同步版本库时才需要联网。
  • 天然的数据完整性校验

  Git通过SHA1值索引和定位数据对象,SHA1即是数据(文件内容,目录树,提交对象等)唯一的标示和索引,也是该数据完整性校验的指纹。

  • 多数操作仅添加数据
  • 三个阶段所处的三个区域

  Git中记录文件变更会经历三个阶段:修改(Modified),暂存(Staged,已经加入下次提交的清单),提交(Committed,已经保存到版本数据目录)。

  这三种阶段里文件数据分别存放在三个独立的区域:工作目录,暂存索引文件(.git/index),本地数据目录(.git/objects目录)。

  Git工作流程可对应的分为三步:(1)修改,(2)暂存:对修改的文件作快照,并保存到暂存区,(3)提交:将暂存区的快照转存到git数据目录。

4.安装Git

Window更推荐TortoiseGit,使用起来会更方便。当然也可以用官网提供的msysGit安装包。

git官网上有针对各个平台的git程序包和GUI工具的下载和安装说明(http://git-scm.com/downloads),网上也有大量的资料。具体安装方法和过程就略过了。

5.Git配置和初始化

可以用git config命令用来设置git环境配置,也可以直接修改配置文件。git config基本格式为:

git config [--global|--system]  <VAR> <VALUE>

git配置保存在3处,对应着三个级别。配置优先级为: 本项目>当前用户>系统全局

作用范围 配置文件 git config选项
系统全局 /etc/gitconfig
windows会在git安装目录下

--system

当前用户 ~/.gitconfig
windows在C:\Documents and Settings\$USER目录下

--global

本项目 项目目录/.git/config

查看配置信息,如果输出中有重复的变量名,那它们来自不同的配置文件,git会使用最后的那一个值。

git config --list

git config <VAR> 

git每次提交版本时的提交者信息(用户名和Email)默认从配置中读取,初始化时必须要设置的。

$ git config --global user.name "John Doe"
$ git config --global user.email johndoe@example.com

git在需要用户输入额外信息时,会自动调用一个文本编辑器,通过下面的命令设置这个编辑器(默认为vi,vim),这一步可略过。

$ git config --global core.editor emacs

设置git解决合并冲突时使用的差异分析工具,可以略过(默认可以用有:kdiff3, tkdiff, meld, xxdiff, emerge, vimdiff, gvimdiff, ecmerge, opendiff等)。

$ git config --global merge.tool vimdiff

6.获取帮助命令

git help <verb>

git <verb> --help|-h

man git-<verb>

《Pro Git》笔记1:起步的更多相关文章

  1. Pro Git 第一章 起步 读书笔记

    Pro Git 笔记 第1章 起步 1.文件的三种状态. 已提交:文件已经保存在本地数据库中了.(commit) 已修改:修改了某个文件,但还没有提交保存.(vim) 已暂存:已经把已修改的文件放在下 ...

  2. Pro Git - 笔记3

    Git Branching Branches in a Nutshell Branches in a Nutshell let’s assume that you have a directory c ...

  3. Pro Git - 笔记2

    Git Basics Getting a Git Repository Initializing a Repository in an Existing Directory For Linux: $ ...

  4. Pro Git - 笔记1

    Getting Started About Version Control Local Version Control Systems Centralized Version Control Syst ...

  5. 《Pro Git》轻松学习版本控制

    转自 https://kindlefere.com/post/333.html 什么是“版本控制”?我为什么要关心它呢?版本控制是一种记录一个或若干文件内容变化,以便将来查阅特定版本修订情况的系统.在 ...

  6. 【Tools】Pro Git 一二章读书笔记

    记得知乎以前有个问题说:如果用一天的时间学习一门技能,选什么好?里面有个说学会Git是个很不错选择,今天就抽时间感受下Git的魅力吧.   Pro Git (Scott Chacon) 读书笔记:   ...

  7. [Git00] Pro Git 一二章读书笔记

    记得知乎以前有个问题说:如果用一天的时间学习一门技能,选什么好?里面有个说学会Git是个很不错选择,今天就抽时间感受下Git的魅力吧.   Pro Git (Scott Chacon) 读书笔记:   ...

  8. Pro Git 学习笔记

    Pro Git 学习笔记 文档地址:Pro Git原文地址:PRO GIT 学习笔记 git常见命令 1.Git起步 初次运行Git前的配置 用户信息 git config --global user ...

  9. 《Pro Git》笔记3:分支基本操作

    <Pro Git>笔记3:Git分支基本操作 分支使多线开发和合并非常容易.Git的分支就是一个指向提交对象的可变指针,极其轻量.Git的默认分支为master. 1.Git数据存储结构和 ...

  10. Git Pro读书笔记

    本文为Git Pro读书笔记,所有内容均来自Git Pro 1 Git基础 1.1 记录每次更新到仓库 在Git里,文件有4种状态,modified, staged, commited, 还有一种状态 ...

随机推荐

  1. Period(poj 1961)

    题目大意: 给你一个字符串,求这个字符串到第i个字符为止的循环节的次数. 比如aabaabaabaab,长度为12.到第二个a时,a出现2次,输出2.到第二个b时,aab出现了2次,输出2.到第三个b ...

  2. swift复合类型

     1.元组类型 (tuple) 元组就是多个元素的组合,是一个用圆括号括起来分号分隔的多个数据的一个集合体. 例如:定义一个学生变量,要求姓名 jim,年龄 19,性别 male 的元组变量为  // ...

  3. sqlserver临时启用和关闭约束

    select  'ALTER TABLE ['  + b.name +  '] NOCHECK CONSTRAINT ' +  a.name +';' as  禁用约束   from  sysobje ...

  4. laravel框架session使用教程

    laravel是一款php框架了,在使用laravel时会碰到session使用问题了,在使用过程中碰到一些问题与一些应用的例子. 用Laravel开发应用,把原有的代码copy过来,以前的代码ses ...

  5. hdu 3183 贪心

    题意:给一个数字,删掉其中的若干位,使得最后的数字最小 就是每次删除数的时候都是删掉第一个比右边数大的数 利用双向链表模拟 #include<cstdio> #include<ios ...

  6. ./configure会报错:pr command not found

    1.2    安装coreutils 请检查${MinGWDir}/msys/1.0/bin(默认为C:/MinGW/msys/1.0/bin)下有没有pr.exe,如果没有,那么在编译libav过程 ...

  7. FileUpload之FileItem

    转自:http://asialee.iteye.com/blog/706079 FileItem类主要是封装了一个File Item或者是FormItem,它的主要的方法如下,需要说明的是对于Form ...

  8. JSON详解(转)

    JSON详解 JSON的全称是”JavaScript Object Notation”,意思是JavaScript对象表示法,它是一种基于文本,独立于语言的轻量级数据交换格式.XML也是一种数据交换格 ...

  9. Android 贝塞尔曲线 折线图

    1.贝塞尔曲线:http://baike.baidu.com/view/60154.htm,在这里理解什么是贝塞尔曲线 2.直接上图: 3.100多行代码就可以画出贝塞尔曲线,直接上代码 packag ...

  10. Myeclipse 60.激活

    Myeclipse 用来开发java web应用是十分的方便的,不过如果没有激活的话,用起来感觉会非常不爽. 当然,个人来说还是非常支持正版的,也鼓励大家支持正版. 好了,下面介绍一下怎么破解Myec ...