git 本地仓库存储简谈

时间:2019-01-23
本文章向大家介绍git 本地仓库存储简谈,主要包括git 本地仓库存储简谈使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

git submodule update 的坑引起的一件事故

最近项目在搞微服务,git用父子模块的形式,具体怎么回事也不太懂,只是我写的代码commit以后,注意还没push.在父目录submodule update 一下,吗的代码全没了.所以就找找有没有什么方法能挽回.百度了一堆也没找到关于git本地仓库的讲解.git能在本地做reset,diff等等操作,文件必需是有备份的,能找到就能恢复(其实是马后炮,我刚开始也没底).果然皇天不负有心人,恢复成功.以下是我对这次处理的心得与相关操作.

git 的本地仓库在.git目录下

如上图.git目录下有一个objects文件,所有的记录全在里边.

所有的提交都会生成一个sha-1值前两位作为目录名,后面38位为文件名

一次提交会分成N份,并生成N个sha-1值并对应该相关文件.只要拿着头文件在sha-1值 cherry-pick 一下数据就全回来了.

目测,git上的操作只会丢失sha-1,而不会做删除操作,只要提交过,数据就不会丢失.

现在来了解一下每个sha-1对应文件里的内容

一般文件的sha-1值用来cherry-pick是会报错的,只能用头文件才可以.

头文件长这样:

没错里边有commit时的备注 还有时间这就方便我们搜索了

当然直接打开是乱码的,用git cat-file -p sha-1 就能拿到里边的内容

写了个bat 过滤了所有文件,拿到了sha-1 ,cherry-pick后数据就都会回来了.

https://download.csdn.net/download/qq_27718453/10934527