PART 1


梗概

git文件流转有三个工作区域:工作目录(working directory)、暂存区域(staging area)、本地仓库(repository)。文件处于上述三个工作区域的状态分别为:已修改、已暂存、已提交。

基本的git工作流程:在working diretory修改文件—>对修改的文件进行快照,保存到staging area—>提交更新,永久存储到repository中。

从远程仓库克隆一个项目到本地当前目录:

$ git clone git://xxx.git

每次修改文件后如何提交到远程仓库

git status:显示当前分支目录、是否有未纳入管理的文件(比如新创建的文件)等。

git add xxx:将某个新文件纳入版本控制并放入暂存区;将修改的文件放入暂存区;

如果不想把某些文件纳入版本控制,可以创建一个.gitingore文件,并列出文件格式,如:

$ cat .gitignore
*.[oa]
*~

git diff:查看尚未暂存的文件更新了哪些部分;
git diff - -staged:查看已暂存的文件与上次提交时的差异;
git commit:提交更新(暂存区域到本地仓库)。
git commit -m “xxxxxx”:给上面的操作加注释。
git commit -a -m “xxxxxx”:把修改的文件直接提交到本地仓库,跳过暂存区域的步骤;

查看提交历史

git log:查看提交历史;
git log -p -2:仅显示最近的两次更新差异;

撤销操作

提交时忘了暂存某些修改,可以先补上暂存操作,再重新提交:

$ git commit -m 'initial commit'
$ git add forgotten_file
$ git commit —amend

使用git reset HEAD xxx取消已经暂存的文件;

远程仓库的使用

远程仓库是指托管在网络上的项目仓库,有些是只读的,有些是可写的。协作开发项目时,需要管理远程仓库,推、拉数据,分享进展。

管理远程仓库,包括添加远程库、移除废弃的远程库、管理远程库分支、定义是否跟踪分支等等;

git remote -v:查看当前的远程库,并显示对应的克隆地址。

git remote add haha git:xxxxxx.git:添加一个新的远程库,并制定一个简单的名字,以便将来引用。

git fetch haha:把上面的远程仓库抓取到本地(因为本地木有)。fetch只是拉取,并不合并。

git fetch origin:抓取从你上次克隆以来别人上传到此远程仓库的所有更新(克隆的仓库都是归于origin名下,即:你使用git clone下载下来的项目,在你本地的分支目录为origin/master)。

git push origin master:把本地master分支推送到远程origin仓库(看上例可知,本地和远程都有个origin/master)。执行成功的前提:所克隆的服务器有写权限且同一时刻没有其他人正在推数据。

git remote show origin:查看远程仓库(本例为origin)的信息。

什么是git分支?

假如我们提交三个文件,git会用blob对象存储每个文件的快照。而在提交的同时,会创建一个提交对象,该提交对象包含一个指向文件快照的指针、包含一个或者0个指向该提交对象的父对象的指针、包含一些其他附属信息。那么单个提交对象在仓库中的数据结构如图:

之后每做一次提交,都会有一个指向上一次提交对象的指针,连续提交三次之后如下图:

分支指向最新一个提交对象,git默认第一个分支为master,那么如下图:

新创建一个分支,就是新增加一个指向最新提交对象的指针:git branch testing

有一个特别指针HEAD,它在哪里就说明当前分支在哪里:

使用git checkout testing切换到新创建的分支:

其实就是HEAD指向新建分支了。

你在新建的分支上提交一个修改,则又新增一个提交对象,变成这样:

你再使用git checkout master切换到master分支,HEAD就又过去了:

如果你在master再作修改,再提交,其实很明显,提交内容是不包括你testing分支的新增内容的,因为它目前指向的是前一个提交对象:

所以,我们所有做的改变分别孤立在不同的分支里,我们可以在不同的分支里反复切换,并要在时机成熟时,将他们合并在一起。

更多内容,关注我的IT微信订阅号:


参考文档:https://git-scm.com/

git:distributed is the new centralized-part1的更多相关文章

  1. 从Perforce到Git的迁移

    公司经过多次兼并.收购之后,开发团队使用的工具自然会出现鱼龙混杂的现象.就拿源代码管理工具来说,我们同时在使用的就有Perforce.Team Foundation.Subversion等.为了节省成 ...

  2. 版本控制工具比较-CVS,SVN,GIT

    首先介绍几个版本控制软件相互比较的重要依据: a.版本库模型(Repository model):描述了多个源码版本库副本间的关系,有客户端/服务器和分布式两种模式.在客户端/服务器模式下,每一用户通 ...

  3. git分布式版本控制玩法

    git分布式版本控制玩法 Git distributed version control play github的配置安装步骤:1.下载git bash(从http://www.git-scm.com ...

  4. GIT版本管理工具

    原文:http://blog.csdn.net/ithomer/article/details/7527877 Git 是一个分布式版本控制工具,它的作者 Linus Torvalds 是这样给我们介 ...

  5. Git 、CVS、SVN比较

    Git .CVS.SVN比较 项目源代码的版本管理工具中,比较常用的主要有:CVS.SVN.Git 和 Mercurial  (其中,关于SVN,请参见我先前的博客:SVN常用命令 和 SVN服务器配 ...

  6. Git学习(一) 版本号管理工具

    Git 是一个分布式版本号控制工具.它的作者 Linus Torvalds 是这样给我们介绍 Git  -- The stupid content tracker(傻瓜式的内容跟踪器) 1. Git ...

  7. Git——版本管理工具(一)

    Git 是一个分布式版本控制工具,它的作者 Linus Torvalds 是这样给我们介绍 Git  —— The stupid content tracker(傻瓜式的内容跟踪器) 1. Git 背 ...

  8. Git 版本管理工具(一)

    转自:http://blog.csdn.net/ithomer/article/details/7527877 Git 是一个分布式版本控制工具,它的作者 Linus Torvalds 是这样给我们介 ...

  9. GIT,SVN,CVS的区别比较

    Git .CVS.SVN比较 项目源代码的版本管理工具中,比较常用的主要有:CVS.SVN.Git 和 Mercurial  (其中,关于SVN,请参见博客:SVN常用命令 和 SVN服务器配置) 目 ...

随机推荐

  1. koa源码之delegate使用

    koa中context可以直接调用request和response属性的重要原因是使用了delegate将req和res的属性代理到context, Delegator.prototype.gette ...

  2. 什么是卷积convolution

    定义 卷积是两个变量在某范围内相乘后求和的结果.如果卷积的变量是序列x(n)和h(n),则卷积的结果 , 其中星号*表示卷积. 当时序n=0时,序列h(-i)是h(i)的时序i取反的结果:时序取反使得 ...

  3. es安装ik后报错无法启动 read write

    https://elasticsearch.cn/question/877 elasticsearch所在路径文件夹名称中带空格,路径错误

  4. python3爬虫_环境安装

    一.环境安装 1.python3安装 官网:https://www.python.org/downloads/ 64 位系统可以下载 Windows x86-64 executable install ...

  5. (JavaScript)实现上传图片实时预览和(文件)大小判断

    唉,为什么我一个做大数据和后端的要为前端耗尽心力啊??!! 昨天在做一个网页时遇到了一个问题,有一处需要插入图片,我原本的想法是获取到上传文件的URL,然后动态插入img标签,设置src为图片的URL ...

  6. hive的排序,分組练习

    hive的排序,分組练习 数据: 添加表和插入数据(数据在Linux本地中) create table if not exists tab1( IP string, SOURCE string, TY ...

  7. 刷题upupup【Java中HashMap、HashSet用法总结】

    HashMap: 常用操作 1. containsKey() 判断HashMap是否包含key 2. containsValue() 判断HashMap是否包含“值为value”的元素 3. get( ...

  8. A context-aware personalized travel recommendation system based on geotagged social media data mining

    文章简介:利用社交网站Flickr上照片的geotag信息将这些照片聚类发现城市里的旅游景点,通过各照片的拍照时间得到用户访问某景点时的时间上下文和天气上下文(利用时间和public API of W ...

  9. redis学习——redis应用场景

    毫无疑问,Redis开创了一种新的数据存储思路,使用Redis,我们不用在面对功能单调的数据库时,把精力放在如何把大象放进冰箱这样的问题上,而是利用Redis灵活多变的数据结构和数据操作,为不同的大象 ...

  10. JS-4-if

    流程控制结构1 顺序结构 alert(10); alert(20);2 分支结构(选择结构) * IF 2.1  if(条件) { 条件成立时执行的语句 } else { 条件不成立时执行的语句 } ...