回滚误操作的解决办法
之前没用过git,有一次在commit本地代码后,还没有push上去,不小心回滚到了之前的版本,代码全丢了。下面记一下解决方法:
首先用git reflog查看操作记录
和git log不同,git log可以查看提交过的版本信息,而got reflog可以查看所有分支的操作记录,包含已经被删除的commit记录。
然后git reset --hard 版本号 回滚到某版本
这部要注意首先要会推到有相关文件的提交,否则reset的时候可能会找不到文件报错。
使用git stash命令暂存代码
版本回退后,由于版本落后于gitlab上的分支项目,因此不能直接push,会报错。因此还要将你本地分支上的代码写到缓存中版存起来。(后来发现有更简单的方法,直接git push origin HEAD --force 强制推到远程分支上)
这时就可以git pull了,把远程分支拉到你的本地分支上。
然后进行git stash pop操作,把暂存的代码释放出来。这时再把本地分支的代码commit push即可。
以上是正常操作。但我在pop之后并没有发现代码合并过去了,而且git stash list竟然是空的,难道被删了?
只好用git fsck看一下,git中被删除的commit并不是真正删除,而是删除了相关的引用,然后变成了悬空对象(dangling commit)
这么多悬空对象,如何找到我想要回退的那个版本的数据?git show +对象ID 即可预览具体信息。后面那一大串是SHA1算出的hash值。找到commit之后用git stash apply还原回去就行了。
git一些常用命令
git checkout -b dev origin/dev 从远程dev分支检到新建的dev本地分支
Git branch 列出本地已经存在的分支
Git branch -r 列出远程分支
git branch -a列出本地和远程分支
git status查看仓库状态
Git commit 有三种状态:untracked未追踪状态/changes tobe commited文件已暂存/changes not updated文件被修改,但未被加入暂存区