简介

GIT与SVN的区别

作为当前最流行的版本控制系统,Git和SVN的几个主要不同之处在于:

(1) Git是分布式的版本控制系统,SVN是集中式的版本控制系统。Git可以先把修改提交到本地仓库中,

等到可以上网或方便的时候,再提交到远程仓库中。这无疑更利于项目开发,同时也可减轻服务器负担。

(2) SVN使用增量文件系统(Delta Storage Systems),即它存储的是每次提交(commit)之间的差异。

Git正好相反,它会把你的每次提交文件的全部内容(snapshot)都记录下来。

(3) Git对于分支有更好的支持,能自动记录分支的合并信息。SVN只能手动追踪,很不方便。

(4) SVN每个目录下都存在.svn目录,而Git的信息只存在项目根目录下的.git目录。

(5) Git的速度更快,不管是本地操作还是远程操作。

对象类型

Git有四种类型的对象:blob、tree、commit、tag。

对象名称用哈希值来表示,SHA1哈希值有40个字符,但是一般用前6个就可以找到相应的对象了。

(1) blob

一个blob用来存储文件的内容。

一个blob对象就是一块二进制数据,它没有指向任何东西或带有任何其它属性。

blob对象和其所对应的文件所在路径、文件名是否被改变都完全没关系,它只是一个数据块而已。

(2) tree

一个tree用于表示内容之间的目录层次关系,相当于文件夹。

A tree is a simple object that has a bunch of pointers to blobs and other trees。

(3) commit

commit对象指向一个tree对象,并且带有相关的描述信息。

The commit object links a physical state of a tree with a description of how we got there and why.

commit的生成:

A commit is usually created by git commit, which creates a commit whose parent is normally the

current HEAD, and whose tree is taken from the content currently stored in the index.

(4) tag

tag存储一个指针,指向某个commit。

Git存储内容的组织结构如下:

每个目录都创建了tree对象(包括根目录),每个文件都创建了一个对应的blob对象。最后只有一个commit对象

来指向根tree对象,这样我们就可以追踪项目每一项提交(commit)的内容。而tag则是特殊的commit。

git目录

每一个项目只有一个Git目录(.git),这和SVN的每个子目录中都有此类目录不同,它位于项目的根目录下。

The Git Directory is the directory that stores all Git's history and meta information for your project -

including all of the objects (commits, trees, blobs, tags), all of the pointers to where different branches

are and more.

在.git目录中,有以下重要文件:

HEAD:pointer to your current branch

config:your configuration preferences

description:description of your project

index:index file,暂存区

logs:a history of where your branches have been

objects:your objects (commits, trees, blobs, tags)

refs:pointers to your branches

工作目录

The Working Directory is the directory that holds the current checkout of the files you are working on.

当你在项目的不同分支间切换时,工作目录里面的文件经常会被替换和删除。所有历史信息都保存在Git目录中,

工作目录只用来临时保存签出(checkout)的文件,你可以编辑工作目录的文件直到下次提交为止。

暂存区

暂存区就是.git/index。

The Git index (.git/index) is used as a staging area between your working directory and your repository.

有了它,你可以把许多内容的修改一起提交(commit)。如果你创建了一个提交,那么提交的是当前暂存区(index)

里面的内容,而不是工作目录中的内容,这又是一个和SVN的不同之处。

下图说明一个commit是怎么产生的:

使用git status可以查看暂存区(index)的内容,包括:

哪些文件被暂存了(staged)

哪些文件被修改了但是没有被暂存(modified, unstaged)

哪些文件没有被跟踪(untracked)

安装

下载地址列表:http://code.google.com/p/git-core/downloads/list

源码包:git-1.9.0.tar.gz

事先需要安装的库:expat、curl、zlib、openssl、zlib-devel

# tar -zxvf git-1.8.0.tar.gz

# cd git-1.8.0

# ./configure --prefix=/usr/local/git

# make && make install

然后设置PATH

在/etc/profile或者~/.bashrc中添加:

export PATH=/usr/local/git/bin:/usr/local/libexec/git-core:$PATH

然后使配置生效:

# . /etc/profile

配置

使用Git的第一件事就是设置你的名字和email,这些就是你在提交commit时的签名。

Git的配置信息分为全局和项目两种,--global参数意味着在进行全局配置,它会影响本机上的每一个Git项目。

全局配置文件:/root/.gitconfig

# git config --global user.name zhangskd

# git config --global user.email zhangskd@xxx.com

项目配置文件:项目/.git/config

# git config user.name zhangskd

# git config user.email zhangskd@xxx.com

也可以直接编辑config文件:

[core]

repositoryformatversion = 0

filemode = true

bare = false

logallrefupdates = true

[user]

name = zhangskd

email = zhangskd@xxx.com

Author

zhangskd @ csdn blog

GIT版本控制 — 简介与安装 (一)的更多相关文章

  1. git的简介,安装以及使用

    1git的简介 Git是什么? Git是目前世界上最先进的分布式版本控制系统(没有之一). Git有什么特点?简单来说就是:高端大气上档次! 2Linus一直痛恨的CVS及SVN都是集中式的版本控制系 ...

  2. git的使用学习(一)git的简介和安装

    Git简介 Git是什么? Git是目前世界上最先进的分布式版本控制系统(没有之一). Git有什么特点?简单来说就是:高端大气上档次! 那什么是版本控制系统? 如果你用Microsoft Word写 ...

  3. Git之简介及安装

    简介 Git是一个分布式版本控制系统,GitHub相当于一个远程仓库,注册账号可免费获得Git远程仓库. GitHub使用参考:https://guides.github.com/activities ...

  4. git版本控制 for window安装和命令行使用

    Git 安装配置 Windows 平台上安装 在 Windows 平台上安装 Git 同样轻松,有个叫做 msysGit 的项目提供了安装包,可以到 GitHub 的页面上下载 exe 安装文件并运行 ...

  5. 版本控制简介,git使用----使用GitHub托管代码

    关于版本控制: 很久以前,人们苦于对写过的代码进行版本的管理,经常过了一段时间想恢复原来写过的代码却又忘了不知道丢到哪儿去了,有的人用加上时间后缀来命名文件的方法,便于后期维护,但是这样做的麻烦也很大 ...

  6. Git SVN 版本控制 简介 总结 MD

    Git 使用准备 主流的 Git 托管网站 GitLab,主流网站,私有仓库也完全免费,功能更强大,页面精美,操作方便 GitHub,最著名的免费Git托管网站,缺点是免费的不支持私有项目 OSChi ...

  7. Git 学习(一)简介及安装

    Git 简介及安装 Git是目前世界上最先进的分布式版本控制系统(没有之一).它的诞生也颇具传奇,Linux创始人Linus花了两周时间自己用C写了一个分布式版本控制系统,这就是Git!有兴趣的话,可 ...

  8. Git版本控制工具(一)----git的安装及创建版本库

    ​[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/ ...

  9. Git(一)Git的简介安装

    一.git历史 同生活中的许多伟大事件一样,Git 诞生于一个极富纷争大举创新的年代.Linux 内核开源项目有着为数众广的参与者.绝大多数的 Linux 内核维护工作都花在了提交补丁和保存归档的繁琐 ...

随机推荐

  1. 关于 minor allele frequency(次等位基因频率)的理解

    引用自NCBI的概念(https://www.ncbi.nlm.nih.gov/projects/SNP/docs/rs_attributes.html#gmaf) Global minor alle ...

  2. Node.js NPM 使用介绍

    NPM是随同NodeJS一起安装的包管理工具,能解决NodeJS代码部署上的很多问题,常见的使用场景有以下几种: 允许用户从NPM服务器下载别人编写的第三方包到本地使用. 允许用户从NPM服务器下载并 ...

  3. docker环境 mysql读写分离 mycat maxscale

    #mysql读写分离测试 环境centos 7.4 ,docker 17.12 ,docker-compose mysql 5.7 主从 mycat 1.6 读写分离 maxscale 2.2.4 读 ...

  4. spring-boot配置静态资源映射的坑:properties文件不能添加注释

    如此博文所述,Spring Boot 对静态资源映射提供了默认配置 默认将 /** 所有访问映射到以下目录:classpath:/staticclasspath:/publicclasspath:/r ...

  5. ngx.ctx

    https://github.com/openresty/lua-nginx-module#ngxctx 要点 生命周期和请求一致 每个请求的ngx.ctx是相互独立的,包括ngx.location. ...

  6. Java程序员的Golang入门指南(下)

    Java程序员的Golang入门指南(下) 4.高级特性 上面介绍的只是Golang的基本语法和特性,尽管像控制语句的条件不用圆括号.函数多返回值.switch-case默认break.函数闭包.集合 ...

  7. RDO Stack:VMs cannot access external network.

    Issue: There are many root causes to make your openstack vm instances cannot be reached from externa ...

  8. linux TCP数据包封装在SKB的过程分析

    在linux中 tcp的数据包的封装是在函数tcp_sendmsg开始的,在函数tcp_sendmsg中用到skb = sk_stream_alloc_skb(sk, select_size(sk, ...

  9. TextView + Spanned实现图文混排以及图片点击交互

    最近要实现图文混排的需求,webview过大,所以想到了用SpannableStringBuilder来实现. 不过参考了大量国内文章,大多数是教你如何实现图文混排,并没有提及图片点击交互的.有翻阅了 ...

  10. SpriteKit游戏开发 Challenge 2: An invincible zombie 问题的另一种解决方法

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 该挑战的目的是僵尸碰到敌人时,将其设置为无敌模式,具体要求如下 ...