学习操作HEAD指针,具体如下:

- 查看Git版本信息

- 移动指针

- 通过移动HEAD指针恢复数据

- 合并版本

拓扑图:

方案: HEAD指针是一个可以在任何分支和版本移动的指针,通过移动指针我们可以将数据还原至任何版本。

每做一次提交操作都会导致git更新一个版本,HEAD指针也跟着自动移动

1. 对数据仓库进行一些修改、提交操作,以产生多个版本,为后面的验证做准备

[root@web2 ~]# git clone root@192.168.2.100:/var/git/project

[root@web2 ~]# cd project

[root@web2 project]# git pull

[root@web2 project]# git status

[root@web2 project]# echo "new file" > new.txt   #写入数据

[root@web2 project]# git add .

[root@web2 project]# git commit -m "add new.txt"

[root@web2 project]# echo "first" >> new.txt     #写入数据

[root@web2 project]# git add .

[root@web2 project]# git commit -m "new.txt:first line"

[root@web2 project]# echo "second" >> new.txt     #写入数据

[root@web2 project]# git add .

[root@web2 project]# git commit -m "new.txt:second"

[root@web2 project]# echo "123" > num.txt    #写入数据

[root@web2 project]# git add .

[root@web2 project]# git commit -m "num.txt:123"

......

2. 查看Git版本信息

[root@web2 project]# git reflog

[root@web2 project]# git log --oneline     #查看Git版本信息

04ddc0f num.txt:789

7bba57b num.txt:456

301c090 num.txt:123

b427164 new.txt:third

0584949 new.txt:second

ece2dfd new.txt:first line

e1112ac add new.txt

3. 移动HEAD指针,将数据还原到任意版本. 提示,当前HEAD指针为HEAD@{0}

[root@web2 project]# git reset --hard 301c0     #恢复到版本301c0

[root@web2 project]# git reflog

301c090 HEAD@{0}: reset: moving to 301c0

04ddc0f HEAD@{1}: commit: num.txt:789

7bba57b HEAD@{2}: commit: num.txt:456

301c090 HEAD@{3}: commit: num.txt:123

b427164 HEAD@{5}: commit: new.txt:third

0584949 HEAD@{6}: commit: new.txt:second

ece2dfd HEAD@{7}: commit: new.txt:first line

e1112ac HEAD@{8}: commit: add new.txt

1a0d908 HEAD@{9}: commit (initial): 初始化

[root@web2 project]# cat num.txt       #查看文件是否为123

123

[root@web2 project]# git reset --hard 7bba57b

[root@web2 project]# cat num.txt        #查看文件是否为123,456

123

456

[root@web2 project]# git reflog       #查看指针移动历史

7bba57b HEAD@{0}: reset: moving to 7bba57b

301c090 HEAD@{1}: reset: moving to 301c0

...

[root@web2 project]# git reset --hard 04ddc0f    #恢复num.txt的所有数据

4. 模拟误删后的数据还原操作

[root@web2 project]# git rm init.txt

rm 'init.txt'      #删除文件

[root@web2 project]# git commit -m "delete init.txt"    #提交本地仓库

[root@web2 project]# git reflog      #查看版本历史

0dc2b76 HEAD@{0}: commit: delete init.txt    #有删除init.txt的记录

7bba57b HEAD@{0}: reset: moving to 7bba57b

301c090 HEAD@{1}: reset: moving to 301c0

...

[root@web2 project]# git reset --hard 04ddc0f            #恢复数据

[root@web2 project]# ls

demo init.txt new.txt num.txt

结束.

git的HEAD指针操作的更多相关文章

  1. git学习 本地常用操作01

    注意: Microsoft的Word格式是二进制格式,因此,版本控制系统是没法跟踪Word文件的改动 不要使用Windows自带的记事本编辑任何文本文件 开始git项目: 初始化本地项目: 初始化:g ...

  2. Git与GitHub常用操作

    --------------------------基本操作--------------------------clone 拷贝远程仓库commit 本地提交push 远程提交pull 更新本地--- ...

  3. 【Git】命令行操作

    Git 命令行操作 1 本地库初始化 git init:初始化本地仓库 效果 注意:.git目录中存放的是本地库相关的子目录和文件,不要删除,也不要胡乱修改. 2 设置签名 形式: 用户名:tom E ...

  4. Git 常见的命令操作

    克隆                git clone git地址 查看分支         git branch 查看git库状态  git status 切换分支         git  che ...

  5. C#指针操作Marshal实例

    static void Main(string[] args) { ,,,}; ,,,}; IntPtr pt = Marshal.AllocHGlobal(a.Length); //从source数 ...

  6. C语言指针操作

    欢迎访问我的新博客:http://www.milkcu.com/blog/ 原文地址:http://www.milkcu.com/blog/archives/pointer-manipulation. ...

  7. Day4:T1小技巧(类似于指针操作)T2搜索+小细节

    Day4:其中有很多小技巧get T1 一直没有听到过像这样的小技巧的略专业名词,有点类似于指针操作,之前有碰到过很多这样的题目 每次都是以不同的形式出现,但是感觉思想还是有点接近的吧(就比如某天有一 ...

  8. Git的纯命令操作,Install,Clone , Commit,Push,Pull,版本回退,撤销更新,分支的创建/切换/更新/提交/合并,代码冲突

    Git的纯命令操作,Install,Clone , Commit,Push,Pull,版本回退,撤销更新,分支的创建/切换/更新/提交/合并,代码冲突 这篇是接着上篇分布式版本库--Windows下G ...

  9. C语言数组操作和指针操作谁更高效

    在上一篇博文  代码优化小技巧(持续更新......) 第三条关于数组和指针谁更高效, 意犹未尽, 决定单独拉出一篇来讲 1. 数组和指针操作对比 #include <stdio.h> i ...

随机推荐

  1. getchar、getch、getche 与 gets()

    一.getchar.getch.getche 1.getchar() getchar()从输入缓冲区读入一个字符,并返回这个字符的ASCII码(即函数返回值为int型),出错返回-1(EOF):如果用 ...

  2. Internet History, Technology, and Security(week9)——Web Security

    Secure Web Connections: Security Public/Private Key - Secure Sockets 凯撒密码容易被破解,后来人们发明了公钥和私钥,由于私钥一定是要 ...

  3. Socket网络通信编程(二)

    1.Netty初步 2.HelloWorld 3.Netty核心技术之(TCP拆包和粘包问题) 4.Netty核心技术之(编解码技术) 5.Netty的UDP实现 6.Netty的WebSocket实 ...

  4. js中获取当前系统时间

    使用var myDate = new Date();//获取系统当前时间 获取特定格式的时间: 1 myDate.getYear(); //获取当前年份(2位) 2 myDate.getFullYea ...

  5. Spring Boot 异步方法的调用

    Spring Boot 异步方法的调用 参考资料: 1.Spring Boot中使用@Async实现异步调用 使用方法 两个步骤: 1.开启配置 @EnableAsync,这一步特别容易忘记,导致测试 ...

  6. shell中的=~的简单用法

    其中 ~ 其实是对后面的正则表达式表示匹配的意思,如果匹配就输出1, 不匹配就输出0 [[ $test =~ ^[0-9]+ ]] && echo 1 || echo 0

  7. 修改mac默认python版本 为python3

    mac一般自带python2.7 可以修改 ~/.bash_profile (具体的path取决于你的python3安装路径): vi ~/.bash_profile # 添加这一行 alias py ...

  8. loj#6487 基础 FFT 练习题

    分析 仔细观察a[i],b[i]的数据范围 于是我们转为枚举所有a[i],b[i]的值 然后暴力即可 代码 #include<bits/stdc++.h> using namespace ...

  9. 错误 error: The following untracked working tree files would be overwritten by merge:README.md

    问题类型 相信很多小伙伴在创建新的git仓库后,会选上添加README.md文件,开始我也没太在意,应该也没有什么问题. 但是当我通过git添加远程仓库,给这个仓库上传代码时,出现了如下问题:erro ...

  10. Linux_VMWare12 Install RHEL7

    目录 目录 前言 Install RHEL7 前言 准备考试,顺便来一波VMWare安装虚拟机的图文详解. Install RHEL7 step1. 选择自定义安装,Next step2. 版本兼容性 ...