学习操作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
结束.