git的远程仓库版本回退
程序员文章站
2022-07-13 17:21:13
...
回滚本地版本
git reflog
git reset --hard Obfafd
直接查看版本历史回滚即可。
回滚远程版本
一种方式是先回滚本地版本,然后提交到远程,但是这时因为本地版本落后远程分支提交远程会失败,必须使用强制推送覆盖远程分支。但是这样还有问题,你的同事这时pull之后,会发现:
$ git status
On branch master
Your branch is ahead of 'origin/master' by 2 commits.
(use "git push" to publish your local commits)
nothing to commit, working directory clean
如果他不知道你回滚了远程版本,或者是个猪队友然后他push了,你辛辛苦苦回滚的远程版本就又复原了。
还有一种比较优雅的方式,是使用revert
git revert HEAD //撤销最近一次提交
git revert HEAD~1 //撤销上上次的提交,注意:数字从0开始
git revert 0ffaacc //撤销0ffaacc这次提交
git revert 命令意思是撤销某次提交。它会产生一个新的提交,虽然代码回退了,但是版本依然是向前的,所以当你用revert回退之后,所有人pull之后,他们的代码也自动的回退了。
但是,要注意以下几点:
revert 是撤销一次提交,所以后面的commit id是你需要回滚到的版本的前一次提交
使用revert HEAD是撤销最近的一次提交,如果你最近一次提交是用revert命令产生的,那么你再执行一次,就相当于撤销了上次的撤销操作,换句话说,你连续执行两次revert HEAD命令,就跟没执行是一样的
使用revert HEAD~1 表示撤销最近2次提交,这个数字是从0开始的,如果你之前撤销过产生了commi id,那么也会计算在内的。
如果使用 revert 撤销的不是最近一次提交,那么一定会有代码冲突,需要你合并代码,合并代码只需要把当前的代码全部去掉,保留之前版本的代码就可以了.
git revert 命令的好处就是不会丢掉别人的提交,即使你撤销后覆盖了别人的提交,他更新代码后,可以在本地用 reset 向前回滚,找到自己的代码,然后拉一下分支,再回来合并上去就可以找回被你覆盖的提交了。
推荐阅读
-
C#/.NET使用git命令行来操作git仓库的方法示例
-
mysql 5.1版本修改密码及远程登录mysql数据库的方法
-
CentOS 最新版本git的安装教程
-
基于金山快盘的Git服务器、快盘+ Git GUI 实现代码版本管理
-
在pycharm中使用git版本管理以及同步github的方法
-
Git分支和版本回退
-
在Linux系统中使用Gitblit工具创建Git仓库的方法
-
Android studio怎么使用git? 使用git查看本地与远程仓库文件的教程
-
Android studio创建远程切换分支git的详细教程
-
android studio git 删除已在远程仓库的文件或文件夹方式