git的HEAD指针操作

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

- 查看Git版本信息

- 移动指针

- 通过移动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

结束.

 

上一篇:常见3种Git服务器的构建


下一篇:基于apache的虚拟主机