高大上的Git

最近学习Git感觉真是是高大上,用简易的方式解决了复杂的版本管理问题。如果要深入介绍Git,其实够一本书了,所以我根据最近学习情况,总结一下Git的基本知识点吧。


一、Git是什么?

Git是目前非常流行的分布式版本管理系统。

开发Git最初目的是为更好地管理Linux内核开发而设计。

  • 什么是版本管理?

    简单说就是记录你的修改。比如你修改一个文档,今天你修改了最后一段文字,过了一周又修改了最后一段文字,但是你后悔了,想恢复到一周前的版本,但是完全记不得之前的内容,怎么办呢?那这个时候就需要版本管理了,版本管理可以记录你的每次修改,这样你就可以回到过去。

  • 为什么使用Git?

    有的人会说,世界这么多版本管理系统,Git有什么好吗?主要有四点:

    • 速度快,操作简单
    • 分布式管理
    • 极其优秀的分支管理
    • 开源项目

二、 Git的安装

  • Mac下的安装

    Mac下安装我推荐使用homebrew,具体方法请参考homebrew的文档

  • Windows下的安装

    在Windows下安装Git,其实和安装其他软件没什么区别,去Git官网下载安装软件即可


三、Git初次体验

安装完后,进入一个新建的文件夹里,我们来体验一下Git的使用

  • 初始化仓库

    // 在当前目录新建一个Git代码库
    git init
    
  • 添加文件

    // 新建一个 a.txt 文件
    touch a.txt
    
    //  添加指定文件到暂存区
    git add a.txt
    
  • 提交文件

    // 提交暂存区到本地仓库区
    git commit -m '添加文件 a.txt'
    

这样你就记录下添加a.txt文件的修改

四、Git的基本使用

4.1 Git的基本概念

  • 工作区 (Working Directory)

    工作区就是你本机操作文件的地方

  • 暂存区 (Stage)

    当你初始化仓库时,你会发现工作区里多了个.git的文件夹,这就是本地仓库。这里有个很重要的区域就是暂存区,当你执行git add的时候,其实就是把文件修改添加到暂存区。

  • 本地仓库 (History)

    .git文件夹就是本地仓库,里面还有一个重要区域就是默认的master分支,当你执行git commit的时候,其实就是把暂存区的所有内容添加到当前分支上。

4.2 添加文件并提交

  • git add

    添加修改文件到暂存区

  • git status

    查看工作区的变化

  • git commit

    把暂存区所有内容提交到当前分支上

  • git pull

    取回远程仓库的变化

  • git push origin master

    上传本地master分支到远程仓库

4.3 版本回退

现代的人总想回到过去,可是时间是回不去的,但是Git可以实现你的愿望。

首先你要知道你想回到哪个版本,通过git log查看当前分支提交记录,
HEAD指向当前分支master,而master指向提交,也就是下面的commit_id (aa81633220d368b5f1...)

git log

commit aa81633220d368b5f1bc0677e676e2a118ab188e (HEAD -> master)
Author: JACK <shizhengchun2015@gmail.com>
Date:   Sun Dec 31 11:28:44 2017 +0800

    添加 b.txt

commit 91ff12ff6685a7316cecf83c85bbcc96a8d63e39
Author: JACK <shizhengchun2015@gmail.com>
Date:   Sun Dec 31 11:24:25 2017 +0800

    添加 a.txt

其次就是让我们回到过去,通过git reset --hard commit_id

git reset --hard 91ff12ff668
HEAD is now at 91ff12f 添加 a.txt

// 查看当前文件夹,发现已经回到添加a.txt的状态了
ls
a.txt

// 再次查看当前提交历史
git log

commit 91ff12ff6685a7316cecf83c85bbcc96a8d63e39 (HEAD -> master)
Author: JACK <shizhengchun2015@gmail.com>
Date:   Sun Dec 31 11:24:25 2017 +0800

    添加 a.txt

这个时候有人发现,那我还能回到添加 b.txt 文件的状态吗?恩,Git无所不能
想要回到未来,通过查看命令历史git reflog,我们就找到添加 b.txt 的commit_id,这样我就可以回到未来了

git reflog

91ff12f (HEAD -> master) HEAD@{0}: reset: moving to 91ff12ff668
aa81633 HEAD@{1}: commit: 添加 b.txt
91ff12f (HEAD -> master) HEAD@{2}: commit (initial): 添加 a.txt


git reset --hard aa81633
HEAD is now at aa81633 添加 b.txt

// 此时文件夹有了b.txt 我们成功回到未来
ls
a.txt b.txt


总结一下:

  • HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset --hard commit_id。

  • 用git log可以查看提交历史,以便确定要回退到哪个版本。

  • 用git reflog查看命令历史,以便确定要回到未来的哪个版本。

五、Git的高级使用

5.1 本地新建Git项目并推送远程空仓库

  • 本地初始化Git项目库

    git init

  • 远程新建空仓库,(注意空仓库就是什么都没有)

    到GitHub新建仓库就行,新建成功就是这个样子

  • 关联本地仓库和远程空仓库

    // origin后面是你自己仓库的地址,别搞错了
    
    git remote add origin git@server-name:path/repo-name.git
    
  • 推送本地仓库到远程

    关联后,使用命令git push -u origin master第一次推送master分支的所有内容

5.2 分支管理

Git还有一个优势就是分支设计非常优秀,之前说过HEAD是指向分支的,当你初始化仓库时会默认产生master分支,所以默认HEAD是指向maser分支的。

其实切换分支的本质就是改变HEAD的指向,工作区什么都没有变。

新建一个分支dev,其实就是新建一个指针dev,并且指向和master相同的提交,同时让HEAD指向dev

// 新建分支dev
git branch dev

// 切换到分支dev
git checkout dev

----------------
// 其实可以一步到位,加参数-b就可以
git checkout -b dev

那现在工作区改变文件,提交文件就是在dev上面了,假如新提交一个commit,那么dev指针向前一步,但maser不变

OK,那我们现在来合并分支,其实原理就是把master指向dev当前的提交

// 首先切换到master分支
git checkout master

// 查看分支,带`*`的符合就是当前分支

git branch

// 把dev分支合并到master分支上

git merge dev

dev的分支使命已经完成了,那我们那删除dev分支,其实删除分支就是删除dev指针而已。

git branch -d dev

Git上面操作分支就是这样简单有效

总结一下:

  • 查看分支:git branch

  • 创建分支:git branch <name>

  • 切换分支:git checkout <name>

  • 创建+切换分支:git checkout -b <name>

  • 合并某分支到当前分支:git merge <name>

  • 删除分支:git branch -d <name>


其实Git还有很多命令,这些其实只是很小的一部分,但是我觉得掌握Git的基本概念后,其实遇到问题,其实可以搜索Git来学习。

才疏学浅,欢迎指导批评


参考链接

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352