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 ...
随机推荐
- Go Web:Handler
Multiplexer根据URL将请求路由给指定的Handler.Handler用于处理请求并给予响应.更严格地说,用来读取请求体.并将请求对应的响应字段(respones header)写入Resp ...
- Docker在Windows上运行NetCore系列(一)使用命令控制台运行.NetCore控制台应用
系列文章:https://www.cnblogs.com/alunchen/p/10121379.html 本篇文章操作系统信息 Windows:Window 10 Visual Studio:201 ...
- popupWindow设置后完美解决返回键响应无效的方案以及popupWindow背景透明方案
// 点击其他地方消失 viewPuwAddNew.setOnTouchListener(new OnTouchListener() { @Override public boolean onTouc ...
- [转]win10中安装JDK8以及环境配置
本文转自:https://blog.csdn.net/yangsummer2426/article/details/80499775 1. 首先下载jdk,网址如下: http://www. ...
- [转]简单科普私钥、地址、助记词、Keystore的区别
本文转自:https://www.jianshu.com/p/d0a4a44685d3 很多人保管不好自己的虚拟财产,发生丢币的情况,很多都是因为不清楚私钥的概念. 私钥(Private Key) 比 ...
- [转]WEB页获取串口数据
本文转自:https://www.cnblogs.com/rockyhm/p/3434200.html 最近做一个B/S的项目,需要读取电子秤的值,之前一直没做过,也没有经验,于是在网上找到很多 大 ...
- nginx ssl证书
server { listen ; server_name xxx.com; root "/home/www/website"; ssl on; ssl_certificate / ...
- SQL语句在数据库中可以执行在mybatis执行不了
这个问题竟然纠结了半个小时! 就问题而言,肯定是出在mybatis中 终于,找到了答案, 原来是DataSource配置问题, 我将配置连接池的数据写到了文件db.properties中, SqlMa ...
- 阅读Java Native源码前的准备
前言 读java native源代码时,我们一般会去网站下载openjdk8源码http://download.java.net/openjdk/jdk8/promoted/b132/openjdk- ...
- 蓝桥杯试题----- 打印大X
打印大X 小明希望用星号拼凑,打印出一个大X,他要求能够控制笔画的宽度和整个字的高度.为了便于比对空格,所有的空白位置都以句点符来代替. 要求输入两个整数m n,表示笔的宽度,X的高度.用空格分开(0 ...