1. 更改本地和远程分支名称
- 将本地分支进行改名:
git branch -m old_branch new_branch
- 将本地分支的远程分支删除:
git push origin :old_branch
- 将改名后的分支push到远程,并让本地分支关联远程分支:
git push --set-upstream origin new_branch
执行完这3步,查看一下,当前成功修改git分支名称
2.撤销上次commit
有时候会因失误提交错了分支,这时候只有撤销commit才能拯救过失。
1.第一种情况:还没有push,只是在本地commit
git reset --soft|--mixed|--hard <commit_id>
git push develop develop --force (本地分支和远程分支都是 develop)
这里的<commit_id>就是每次commit的SHA-1,可以在git log里查看到
–mixed 会保留源码,只是将git commit和index 信息回退到了某个版本.
–soft 保留源码,只回退到commit信息到某个版本.不涉及index的回退,如果还需要提交,直接commit即可.
–hard 源码也会回退到某个版本,commit和index 都会回退到某个版本.(注意,这种方式是改变本地代码仓库源码)
2.commit push 代码已经更新到远程仓库
如果已经push到线上,想回退本地和线上版本,可执行下面操作
git revert <commit_id>
revert 之后你的本地代码会回滚到指定的历史版本,这时你再 git push 既可以把线上的代码更新。
注意:git revert是用一次新的commit来回滚之前的commit,git reset是直接删除指定的commit,
看似达到的效果是一样的,其实完全不同。
第一:上面我们说的如果你已经push到线上代码库, reset 删除指定commit以后,你git push可能导
致一大堆冲突.但是revert 并不会.
第二:如果在日后现有分支和历史分支需要合并的时候,reset 恢复部分的代码依然会出现在历史分支里.
但是revert 方向提交的commit 并不会出现在历史分支里.
第三:reset 是在正常的commit历史中,删除了指定的commit,这时 HEAD 是向后移动了,而 revert
是在正常的commit历史中再commit一次,只不过是反向提交,他的 HEAD 是一直向前的.
3.恢复 git reset -hard 的误操作
不久之前本来只是想清空一下本地提交commit,结果却把代码搞丢了,这时候的我焦急得很,却意外发现git的历史记录是不可修改的,也就是说你不能更 改任何已经发生的事情。你做的任何操作都只是在原来的操作上修改。也就是说,即使你删除了一个分支,修改了一个提交,或者强制重置,你仍然可以回滚这些操 作。
我们来看一下具体操作
你现在看git的历史记录,你可以看到两次提交:
* 98abc5a (HEAD, master) more stuff added to foo
* b7057a9 initial commit
现在让我们来重置回第一次提交的状态:
$ git reset --hard b7057a9
$ git log
* b7057a9 (HEAD, master) initial commit
这看起来我们是丢掉了我们第二次的提交,没有办法找回来了。但是 reflog 就是用来解决这个
问题的。简单的说,它会记录所有HEAD的历史,也就是说当你做 reset,checkout等操作的时候,
$ git reflog
b7057a9 HEAD@{0}: reset: moving to b7057a9
98abc5a HEAD@{1}: commit: more stuff added to foo
b7057a9 HEAD@{2}: commit (initial): initial commit
这些操作会被记录在reflog中。