GitHub-暂存区与版本回退
参考博文:廖雪峰Git教程
1. 工作区和暂存区
Git和其他版本控制系统如SVN的一个不同之处就是有暂存区的概念。
1.1. 工作区(Working Directory)
就是你在电脑里能看到的目录.比如:zhangtest
[root@mini05 zhangtest]# pwd
/opt/git_repository/zhangtest
[root@mini05 zhangtest]# ll
total
-rw-r--r-- root root Sep : README.md
-rw-r--r-- root root Sep : test.info
1.2. 版本库(Repository)
工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。
Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD。

前面讲了我们把文件往Git版本库里添加的时候,是分两步执行的:
第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区;
第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。
你可以简单理解为,需要提交的文件修改通通放到暂存区,然后,一次性提交暂存区的所有修改。
测试实践
对README.md追加一些内容;新建LICENSE并添加内容。
[root@mini05 zhangtest]# ll
total
-rw-r--r-- root root Sep : LICENSE
-rw-r--r-- root root Sep : README.md
-rw-r--r-- root root Sep : test.info
[root@mini05 zhangtest]#
[root@mini05 zhangtest]# git status
# On branch master
# Your branch is ahead of 'origin/master' by commits.
# (use "git push" to publish your local commits)
#
# Changes not staged for commit:
# (use "git add <file>..." to update what will be committed)
# (use "git checkout -- <file>..." to discard changes in working directory)
#
# modified: README.md
#
# Untracked files:
# (use "git add <file>..." to include in what will be committed)
#
# LICENSE
no changes added to commit (use "git add" and/or "git commit -a")
由上可知:Git非常清楚地告诉我们,README.txt被修改了,而LICENSE还从来没有被添加过,所以它的状态是Untracked。
现在,使用两次命令git add,把readme.txt和LICENSE都添加后,用git status再查看一下:
[root@mini05 zhangtest]# git add README.md
[root@mini05 zhangtest]# git add LICENSE
[root@mini05 zhangtest]#
[root@mini05 zhangtest]# git status
# On branch master
# Your branch is ahead of 'origin/master' by commits.
# (use "git push" to publish your local commits)
#
# Changes to be committed:
# (use "git reset HEAD <file>..." to unstage)
#
# new file: LICENSE
# modified: README.md
#
现在,暂存区的状态就变成这样了:

所以,git add命令实际上就是把要提交的所有修改放到暂存区(Stage),然后,执行git commit就可以一次性把暂存区的所有修改提交到分支。
[root@mini05 zhangtest]# git commit -m "understand how stage works"
[master 53f0f2e] understand how stage works
files changed, insertions(+)
create mode LICENSE
一旦提交后,如果你又没有对工作区做任何修改,那么工作区就是“干净”的:
[root@mini05 zhangtest]# git status
# On branch master
# Your branch is ahead of 'origin/master' by commits.
# (use "git push" to publish your local commits)
#
nothing to commit, working directory clean
现在版本库变成了这样,暂存区就没有任何内容了:

2. 版本回退
在README.md追加了如下内容,并进行了提交。
Git is a distributed version control system.
Git is free software distributed under the GPL.
提交
[root@mini05 zhangtest]# vim README.md
# zhangtest
zhangtest
张三
Git is a distributed version control system.
Git is free software.
Git is a distributed version control system.
Git is free software distributed under the GPL.
[root@mini05 zhangtest]# git add . # 添加到暂存区
[root@mini05 zhangtest]# git commit -m "append GPL" # 提交到仓库
2.1. 查看版本日志信息
# 使用 git add . 就是针对当前目录
[root@mini05 zhangtest]# git log README.md # 针对README.md文件
commit 9f27dce0f57cf811a8e3bdab545e8b98ca9bd41f
Author: Zhang San <zhanglianghhh@.com>
Date: Sun Sep :: + append GPL commit 65a58f2661c4d73dc0dc9c2e5bff4c350c42c98e
Author: Zhang San <zhanglianghhh@.com>
Date: Mon Sep :: + add info commit d4fb57e8a892060db07fe862058a1a8477be49aa
Author: 张亮 <zhanglianghhh@.com>
Date: Mon Sep :: + Update README.md commit e7306765445375e4c1b52ebde07a666da5517b22
Author: 张亮 <zhanglianghhh@.com>
Date: Mon Sep :: + Initial commit
2.2. 简化版本日志
[root@mini05 zhangtest]# git log --pretty=oneline README.md
9f27dce0f57cf811a8e3bdab545e8b98ca9bd41f append GPL
65a58f2661c4d73dc0dc9c2e5bff4c350c42c98e add info
d4fb57e8a892060db07fe862058a1a8477be49aa Update README.md
e7306765445375e4c1b52ebde07a666da5517b22 Initial commit
2.3. 版本回退到65a58f2661
在Git中,用HEAD表示当前版本,也就是最新的提交9f27dce...(注意我的提交ID和你的肯定不一样),上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。
# git reset --hard 65a58f2661 回退到指定版本,好处就是不用计算到底回退几个版本
[root@mini05 zhangtest]# git reset --hard HEAD^ # 回退到上一个版本
HEAD is now at 65a58f2 add info
[root@mini05 zhangtest]# cat README.md # 查看内容,可见以回退到上一个版本
# zhangtest
zhangtest
张三
Git is a distributed version control system.
Git is free software.
[root@mini05 zhangtest]# git log --pretty=oneline README.md # 根据提交日志,也可知已回退
65a58f2661c4d73dc0dc9c2e5bff4c350c42c98e add info
d4fb57e8a892060db07fe862058a1a8477be49aa Update README.md
e7306765445375e4c1b52ebde07a666da5517b22 Initial commit
2.4. 回退原理
Git的版本回退速度非常快,因为Git在内部有个指向当前版本的HEAD指针,当你回退版本的时候,Git仅仅是把HEAD从指向append GPL:

改为指向add info:

然后顺便把工作区的文件更新了。所以你让HEAD指向哪个版本号,你就把当前版本定位在哪。
2.5. 记录每一次命令
回退到了某个版本,想恢复到新版本怎么办?找不到新版本的commit id怎么办?
Git提供了一个命令git reflog用来记录你的每一次命令:
用git reflog查看命令历史,以便确定要回到未来的哪个版本。
[root@mini05 zhangtest]# git reflog
65a58f2 HEAD@{}: reset: moving to 65a58f2661
9f27dce HEAD@{}: reset: moving to 9f27dce0f57cf
65a58f2 HEAD@{}: reset: moving to HEAD^
9f27dce HEAD@{}: commit: append GPL
65a58f2 HEAD@{}: commit: add info
d4fb57e HEAD@{}: pull git@github.com:zhanglianghhh/zhangtest.git: Fast-forward
e730676 HEAD@{}: clone: from git@github.com:zhanglianghhh/zhangtest.git
GitHub-暂存区与版本回退的更多相关文章
- [git]入门-工作区、暂存区、版本库
转载整理自:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/0013743256 ...
- git工作区、暂存区、版本库之间的关系
区分三者关系 Git最让你迷惑的无非是它里面的各种概念了,如果是刚开始接触Git希望看完本篇介绍之后有一个清晰的认识,笔者认识也有限这里只说说个人对使用Git的感受,说一下它里面的几个最常用的概念的理 ...
- 【Git】(1)---工作区、暂存区、版本库、远程仓库
工作区.暂存区.版本库.远程仓库 一.概念 1.四个工作区域 Git本地有四个工作区域:工作目录(Working Directory).暂存区(Stage/Index).资源库(Repository或 ...
- 【原创】Git删除暂存区或版本库中的文件
0 基础 我们知道Git有三大区(工作区.暂存区.版本库)以及几个状态(untracked.unstaged.uncommited),下面只是简述下Git的大概工作流程,详细的可以参见本博客的 ...
- Git工作区、暂存区和版本库
基本概念 我们先来理解下Git 工作区.暂存区和版本库概念 工作区:就是你在电脑里能看到的目录. 暂存区:英文叫stage, 或index.一般存放在 ".git目录下" 下的in ...
- Git 工作区、暂存区和版本库
基本概念 我们等来理解下Git工作区.暂存区和版本库概念 工作区:就是你在电脑里能看到的目录 强烈推荐git新手阅读 暂存区:英文叫stage,或index.一般存放在igt 目录下的index文件( ...
- Git-Runoob:Git 工作区、暂存区和版本库
ylbtech-Git-Runoob:Git 工作区.暂存区和版本库 1.返回顶部 1. Git 工作区.暂存区和版本库 基本概念 我们先来理解下Git 工作区.暂存区和版本库概念 工作区:就是你在电 ...
- Git 工作区、暂存区和版本库、操作流程
Git 工作区.暂存区和版本库 基本概念 我们先来理解下Git 工作区.暂存区和版本库概念 工作区:就是你在电脑里能看到的目录. 暂存区:英文叫stage, 或index.一般存放在 ".g ...
- 【第四篇】-Git 工作区、暂存区和版本库之Spring Cloud直播商城 b2b2c电子商务技术总结
Git 工作区.暂存区和版本库 基本概念 我们先来理解下 Git 工作区.暂存区和版本库概念: 工作区:就是你在电脑里能看到的目录. 暂存区:英文叫 stage 或 index.一般存放在 .git ...
随机推荐
- [转]Database Transactions in Laravel
本文转自:https://fideloper.com/laravel-database-transactions Laravel's documentation on Database Transac ...
- 记录.net使用ueditor富文本编辑器
UEditor是什么 最近在在项目的时候使用到了百度的富文本编辑器.官网有详细的操作流程文档.这里我只是记录项目中常用到的一些事件.以便日后可以方便查询. UEditor是百度的一个javascrip ...
- openssl基本原理 + 生成证书 + 使用实例
前期准备 : 安装xampp:打开文件E:\xampp\apache\bin\openssl.exe 右键 以管理员身份运行 ------转载自 https://blog.csdn.net/oldm ...
- python使用tcp实现一个简单的下载器
上一篇中介绍了tcp的流程,本篇通过写一个简单的文件下载器程序来巩固之前学的知识. 文件下载器的流程如下: 客户端: 输入目标服务器的ip和port 输入要下载文件的名称 从服务器下载文件保存到本地 ...
- java安全管理器SecurityManager介绍
java安全管理器类SecurityManager简单剖析: javadoc介绍: SecurityManager是一个允许应用实现一种安全策略的类.它允许一个应用去明确,在执行一个可能安全或者敏感的 ...
- 使用Linux的Crontab定时执行PHP脚本
0 */6 * * * /home/kdb/php/bin/php /home/kdb/apache/htdocs/lklkdbplatform/kdb_release/Crontab/index.p ...
- 自定义View的三个构造函数
自定义View有三个构造方法,它们的作用是不同的. public MyView(Context context) { super(context); } public MyView(Context c ...
- 取消IE、Office、Wmp首次开启提示
一.取消IE首次开启提示 1.运行框输入gpedit.msc.打开组策略配置 2.本地计算机策略-计算机配置-管理模板-windows组件-Internet Explorer,查找右边“阻止执行首次运 ...
- (后端)spring的@Transactional注解详细用法(转)
转自一人浅醉-博客园: 事务隔离级别 隔离级别是指若干个并发的事务之间的隔离程度.TransactionDefinition 接口中定义了五个表示隔离级别的常量: TransactionDefinit ...
- sh命令
sh或是执行脚本,或是切换到sh这个bash里,默认的shell是bash,你可以试试tcsh啊,csh啊,ksh,zsh什么的,看看别的shell是什么样子的.当然,linux中sh是链接到bash ...