git本地版本回退与远端版本回退(回滚)

预备知识:

一个commit对应这一个版本,有一个commit id,40位的16进制数字,通过SHA1计算得到,不同的文件计算出来的SHA1值不同(有很小的几率相同,可忽略),这样每一个提交都有其独特的id。每提交一个新版本,实际上Git就会把它们自动串成一条时间线。
在Git中,HEAD表示当前版本,也就是e620a6ff0940a8dff…,HEAD^表示上一个版本,HEAD^^表示上上一个版本,往上100个版本可以写成HEAD加连续100个^,也可以写成:HEAD~100。

git log:该命令显示从最近到最远的提交日志。

commit e620a6ff0940a8dff91e0d252f30e4d138ec37be
Author: TangShengqin <15527733782@163.com>
Date:   Wed Jan 3 10:35:44 2018 +0800
    练习版本回退,假设这是版本3
commit 33342d9870f104719d351539a15e74a1382407ea
Author: TangShengqin <15527733782@163.com>
Date:   Wed Jan 3 10:34:03 2018 +0800
    练习版本回退,假设这是版本2
......

git log - -pretty=oneline:将只会显示提交的commit id号和对应的注释。(这里是两个-,Markdown显示两个-为一个-)

e620a6ff0940a8dff91e0d252f30e4d138ec37be 练习版本回退,假设这是版本3
33342d9870f104719d351539a15e74a1382407ea 练习版本回退,假设这是版本2
......

git reset –hard id 之前的版本日志信息:

git log --pretty=oneline
e620a6ff0940a8dff91e0d252f30e4d138ec37be 练习版本回退,假设这是版本3
33342d9870f104719d351539a15e74a1382407ea 练习版本回退,假设这是版本2

git reset –hard commit_id 或则是 git reset –hard HEAD^

git reset --hard HEAD^   # hard选项,表示彻底将工作区、暂存区和版本库记录恢复到指定的版本库

使用git reset –hard 进行版本回退之后,在本地查看README.md,里面已经变为版本2对应的内容了。

如果你在本地做了错误提交,那么回退版本的方法很简单
1.先用下面命令找到要回退的版本的commit id:

git reflog 

2.接着回退版本:

git reset --hard a7e1d279

a7e1d279就是你要回退的版本的commit id的前面几位。

远程分支版本回退的方法
如果你的错误提交已经推送到自己的远程分支了,那么就需要回滚远程分支了。
1.首先要回退本地分支:

git reflog
git reset --hard Obfafd

2.紧接着强制推送到远程分支:

git push -f origin master ## 这里假设只有一个master分支

origin就是一个名字,它是在你clone一个托管在Github上代码库时,git为你默认创建的指向这个远程代码库的标签,origin指向的是repository,master只是这个repository中默认创建的第一个branch。当你git push的时候因为origin和master都是默认创建的,所以可以这样省略。
关于origin意义,知乎上的讨论
注意:本地分支回滚后,版本将落后远程分支,必须使用强制推送覆盖远程分支,否则无法推送到远程分支

  • 44
    点赞
  • 138
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: 在使用Git进行代码版本控制时,有时需要回退到某个指定的版本。但是,有一种情况是我们不想回滚中间的某些版本,只想回退到指定版本之前或之后的版本。那么,该如何做呢? 其实,Git提供了多种方式实现这个需求。下面给大家介绍几种比较常用的方法: 1. 使用git cherry-pick命令:首先,使用git log命令查看需要回滚版本号,然后使用git cherry-pick命令选中需要回滚版本。这样,Git会将该版本之后新增的代码复制到当前分支中,而不会影响中间的代码。 2. 使用git rebase命令:首先,使用git log命令查看需要回滚版本号,然后使用git rebase命令指定需要回滚到的版本号。这样,Git会将指定版本之后新增的代码合并到当前分支中,合并完成后,我们再使用git rebase命令将中间的代码重新合并到代码库中。 3. 使用git revert命令:首先,使用git log命令查看需要回滚版本号,然后使用git revert命令指定需要回滚版本号。这样,Git会创建一个新的提交,将指定版本的更改撤销,但是保留中间的代码。 综上所述,我们可以根据不同情况选择不同的方式实现Git回退指定版本中间的代码不回滚的需求。无论哪种方式,都需要注意在操作之前备份好代码,以防止不必要的损失。 ### 回答2: 在Git回退指定版本的操作常用于撤销错误的提交或回到某个早期版本。但是,有些情况下我们并不想回滚所有中间的代码,而是只想回退到某个版本之前的部分代码。如何实现这样的目标呢?下面介绍两种方法。 方法一:利用Git的分支合并功能 首先,我们需要创建一个新的分支,并切换到该分支。命令如下: ``` git checkout -b new_branch commit_id ``` 其中,commit_id是想要回退到的版本号。创建并切换完毕后,我们可以在新的分支上手动编辑代码,将不需要回滚的部分保留下来。然后,使用Git的合并功能将新分支合并到主分支,代码会被合并到主分支上,而不会回滚中间的代码。命令如下: ``` git merge new_branch ``` 方法二:利用Git的部分重置功能 另外一种方法是利用Git的部分重置功能,先重置到指定版本,再将不需要回滚的部分重新提交。命令如下: ``` git reset --hard commit_id ``` 其中,commit_id是想要回退到的版本号。这个命令会将代码库重置到指定版本,包括暂存区和工作区。但是,不需要回滚的部分也会被删除掉。 接下来,我们可以使用以下命令撤销需要回退的部分: ``` git checkout HEAD -- file_name ``` 其中,file_name 是需要撤销的文件名,使用该命令可以将该文件恢复到最新的提交版本,而不会覆盖重置的部分。 最后,我们需要重新提交剩余的部分,命令如下: ``` git add . git commit -m "Commit message" ``` 这个命令会将剩余的部分重新提交到代码库中。 以上就是两种回退指定版本但不回滚中间代码的方法。可以根据实际情况选择使用哪种方法。总之,对于Git来说,所有的修改都可以恢复和撤销,只要我们熟悉Git的使用方式,就可以轻松管理代码库。 ### 回答3: 在git中,回退指定版本是非常常见的操作,它可以帮助我们回到之前的某个版本。但是,有时候我们只想回滚某个版本之后的代码,而不是所有的代码。那么怎样实现呢? 首先,我们需要了解一些git的基本操作。git回退指定版本有两种方式:一种是使用git reset命令;另一种是使用git revert命令。这两种方法可以实现不同的回退效果。 如果我们想回退某个版本之后的代码,而不是所有的代码,我们可以使用git revert命令。该命令会创建一个新的提交,撤销之前的提交,但是保留后续提交的代码。机理类似于"反操作"。 下面是具体的步骤: 1. 首先,我们需要知道想要回滚到的那个版本号,可以使用git log命令查看。假设我们要回滚到e279f848这个版本。 2. 然后,使用git revert命令回滚到该版本。具体命令如下: git revert e279f848 这个命令会打开一个编辑器,让你输入提交信息。默认情况下,提交信息会包含一些有关回滚操作的描述,但你也可以自己修改。 3. 查看撤销的提交git log 现在你应该能看到一个新的提交,它撤销了之前的提交,并保留了后续提交的代码。 总的来说,git revert命令是一种很好的方法,可以帮助我们回滚指定版本之后的代码,而不是所有的代码。无需担心丢失后续提交的代码,保留他们的同时反操作需要回退的代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值