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