2019独角兽企业重金招聘Python工程师标准>>>

本博文转载自:http://www.tech126.com/git-reset/; 如果看不懂的话,请在git下练习,如果练习后任然有不懂的,可以留言也可以发送邮件到luoquantao@126.com

reset命令有3种方式:

1:git reset –mixed:此为默认方式,不带任何参数的git reset,即时这种方式,它回退到某个版本,只保留源码,回退commit和index信息

2:git reset –soft:回退到某个版本,只回退了commit的信息,不会恢复到index file一级。如果还要提交,直接commit即可

3:git reset –hard:彻底回退到某个版本,本地的源码也会变为上一个版本的内容

#回退所有内容到上一个版本 

git reset HEAD^ 

#回退a.py这个文件的版本到上一个版本 

git reset HEAD^ a.py 

#向前回退到第3个版本 

git reset –soft HEAD~3

#将本地的状态回退到和远程的一样 

git reset –hard origin/master 

#回退到某个版本 

git reset 057d 

#回退到上一次提交的状态,按照某一次的commit完全反向的进行一次commit 

git revert HEAD 

如果我们某次修改了某些内容,并且已经commit到本地仓库,而且已经push到远程仓库了

这种情况下,我们想把本地和远程仓库都回退到某个版本,该怎么做呢?

前面讲到的git reset只是在本地仓库中回退版本,而远程仓库的版本不会变化

这样,即时本地reset了,但如果再git pull,那么,远程仓库的内容又会和本地之前版本的内容进行merge

这并不是我们想要的东西,这时可以有2种办法来解决这个问题:

1:直接在远程server的仓库目录下,执行git reset –soft 10efa来回退。注意:在远程不能使用mixed或hard参数

2:在本地直接把远程的master分支给删除,然后再把reset后的分支内容给push上去,如下:

#新建old_master分支做备份
git branch old_master
#push到远程
git push origin old_master:old_master
#本地仓库回退到某个版本
git reset –hard bae168
#删除远程的master分支
git push origin :master
#重新创建master分支
git push origin master  

在删除远程master分支时,可能会有问题,见下:

$ git push origin :master
error: By default, deleting the current branch is denied, because the next
error: 'git clone' won't result in any file checked out, causing confusion.
error:
error: You can set 'receive.denyDeleteCurrent' configuration variable to
error: 'warn' or 'ignore' in the remote repository to allow deleting the
error: current branch, with or without a warning message.
error:
error: To squelch this message, you can set it to 'refuse'.
error: refusing to delete the current branch: refs/heads/master
To git@xx.sohu.com:gitosis_test  ! [remote rejected] master (deletion of the current branch prohibited)
error: failed to push some refs to 'git@xx.sohu.com:gitosis_test'

这时需要在远程仓库目录下,设置git的receive.denyDeleteCurrent参数

git receive.denyDeleteCurrent warn

然后,就可以删除远程的master分支了

虽然说有以上2种方法可以回退远程分支的版本,但这2种方式,都挺危险的,需要谨慎操作……

转载于:https://my.oschina.net/u/3157270/blog/909495

Git版本恢复命令reset(转载)相关推荐

  1. git-代码撤销、回滚到任意版本(git回滚命令reset、revert的区别)

    文章目录 一.Git 代码撤销.回滚到任意版本(当误提代码到本地或master分支时) 二.git回滚命令reset.revert的区别 1. 背景知识 2. 方法一:git reset(回退) 3. ...

  2. git版本回退命令_git 版本回退 撤销 删除

    1 未使用 git add 缓存代码时(在工作区的时候) 可以使用 git checkout -- filepathname (比如: git checkout -- readme.md  ,不要忘记 ...

  3. git回滚命令reset、revert的区别

    ##使用git,总有一天会遇到下面的问题: (1)改完代码匆忙提交,上线发现有问题,怎么办? 赶紧回滚. (2)改完代码测试也没有问题,但是上线发现你的修改影响了之前运行正常的代码报错,必须回滚. 所 ...

  4. Git版本回退之 reset 和 revert

    在开发过程中,可能会遇到过错误提交的情况.这种情况下,先不要着急,可以通过以下两个命令来帮助你优雅的实现版本回退. git reset 假如现在有如下几个提交: 其中:A 和 B 是正常提交,而 C ...

  5. git版本回退命令_Git学习版本回退和管理文件的修改及删除操作

    版本回退 前面我们成功的提交了一次mygit.txt,下面咱对它进行修改,内容如下: Hello Git Git is so easy. 然后用git status来跟踪该文件的状态: 可以看到hel ...

  6. Git 版本还原命令

    转载:https://blog.csdn.net/yxlshk/article/details/79944535 1.需求场景: 在利用github实现多人协作开发项目的过程中,有时会出现错误提交的情 ...

  7. git版本回退命令_刘先生

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

  8. GIT常用基础命令总结

    三个配置文件 /etc/gitconfig 文件:系统中对所有用户都普遍适用的配置.若使用 git config 时用--system 选项,读写的就是这个文件. ~/.gitconfig 文件:用户 ...

  9. GIt/Github常用命令

    1)git init:初始化本地仓库 2)创建文件:touch read.txt 3)当操作本地的文件时,使用常用的命令,如(mv,ls..)就可以操作,当操作暂存区的文件时需要在命令前家git,并且 ...

最新文章

  1. php使用webservivce_基于SSM框架实现简单的登录注册的示例代码
  2. leetcode63. Unique Paths II
  3. golang 文件操作 创建 读写 复制移动 权限 删除
  4. 计算机系统中存储管理是,《计算机操作系统5、存储管理.doc
  5. 784. Letter Case Permutation
  6. Python 解析构建数据大杂烩 -- csv、xml、json、excel
  7. linux tomcat 发布servlet,SpringBoot项目使用war包部署至云服务器(Linux+Tomcat)
  8. 启动Tomcat服务时,出现org.apache.catalina.startup.VersionLoggerListener报错
  9. Web页面输出Excel的数字问题解决方法
  10. 6.0新特性 权限管理方式
  11. 多元函数极限求法(二元函数)
  12. 差分管电路图_电子管差分放大电路改造方案
  13. springboot毕设项目基于SpringBoot的个人理财系统ibx9h(java+VUE+Mybatis+Maven+Mysql)
  14. 怎么恢复oracle的包,Oracle的恢复管理器及DBMS_JOB包分析
  15. 高德导航在天地图显示
  16. c语言错误c2059 void,c2059(c语言错误代码c2059)
  17. 【云笔记9】Layui前端框架
  18. 基于国产芯片的刀片服务器,至强E5核心助力 5万左右刀片服务器导购
  19. LeetCode--704.二分查找(C++)
  20. Pytorch中的DDP

热门文章

  1. gge加MySQL_mysql分布式中间件cobar
  2. linux编程排序,Linux下简单的c编程——选择法排序
  3. configureWebpack与chainWebpack
  4. c语言追加字符串_Redis源码解析二--简单动态字符串
  5. linux 下nm命令输出,Linux nm命令介绍
  6. [CSS3] touch-action设置移动端拖动行为
  7. Linux引出环境变量的关键字,学习记录008-linux常用命令/设置系统and用户环境变量two(示例代码)...
  8. git 改了一段代码不想要了_想要壁纸不收费吗?简简单单用python代码实现
  9. Android的触摸监听器实现滑动图片
  10. wordpress修改mysql端口_Wordpress更改端口后访问自动跳转老端口