Git版本恢复命令reset(转载)
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(转载)相关推荐
- git-代码撤销、回滚到任意版本(git回滚命令reset、revert的区别)
文章目录 一.Git 代码撤销.回滚到任意版本(当误提代码到本地或master分支时) 二.git回滚命令reset.revert的区别 1. 背景知识 2. 方法一:git reset(回退) 3. ...
- git版本回退命令_git 版本回退 撤销 删除
1 未使用 git add 缓存代码时(在工作区的时候) 可以使用 git checkout -- filepathname (比如: git checkout -- readme.md ,不要忘记 ...
- git回滚命令reset、revert的区别
##使用git,总有一天会遇到下面的问题: (1)改完代码匆忙提交,上线发现有问题,怎么办? 赶紧回滚. (2)改完代码测试也没有问题,但是上线发现你的修改影响了之前运行正常的代码报错,必须回滚. 所 ...
- Git版本回退之 reset 和 revert
在开发过程中,可能会遇到过错误提交的情况.这种情况下,先不要着急,可以通过以下两个命令来帮助你优雅的实现版本回退. git reset 假如现在有如下几个提交: 其中:A 和 B 是正常提交,而 C ...
- git版本回退命令_Git学习版本回退和管理文件的修改及删除操作
版本回退 前面我们成功的提交了一次mygit.txt,下面咱对它进行修改,内容如下: Hello Git Git is so easy. 然后用git status来跟踪该文件的状态: 可以看到hel ...
- Git 版本还原命令
转载:https://blog.csdn.net/yxlshk/article/details/79944535 1.需求场景: 在利用github实现多人协作开发项目的过程中,有时会出现错误提交的情 ...
- git版本回退命令_刘先生
如果你在本地做了错误提交,那么回退版本的方法很简单 1.先用下面命令找到要回退的版本的commit id: git reflog 2.接着回退版本: git reset --harda7e1d279 ...
- GIT常用基础命令总结
三个配置文件 /etc/gitconfig 文件:系统中对所有用户都普遍适用的配置.若使用 git config 时用--system 选项,读写的就是这个文件. ~/.gitconfig 文件:用户 ...
- GIt/Github常用命令
1)git init:初始化本地仓库 2)创建文件:touch read.txt 3)当操作本地的文件时,使用常用的命令,如(mv,ls..)就可以操作,当操作暂存区的文件时需要在命令前家git,并且 ...
最新文章
- php使用webservivce_基于SSM框架实现简单的登录注册的示例代码
- leetcode63. Unique Paths II
- golang 文件操作 创建 读写 复制移动 权限 删除
- 计算机系统中存储管理是,《计算机操作系统5、存储管理.doc
- 784. Letter Case Permutation
- Python 解析构建数据大杂烩 -- csv、xml、json、excel
- linux tomcat 发布servlet,SpringBoot项目使用war包部署至云服务器(Linux+Tomcat)
- 启动Tomcat服务时,出现org.apache.catalina.startup.VersionLoggerListener报错
- Web页面输出Excel的数字问题解决方法
- 6.0新特性 权限管理方式
- 多元函数极限求法(二元函数)
- 差分管电路图_电子管差分放大电路改造方案
- springboot毕设项目基于SpringBoot的个人理财系统ibx9h(java+VUE+Mybatis+Maven+Mysql)
- 怎么恢复oracle的包,Oracle的恢复管理器及DBMS_JOB包分析
- 高德导航在天地图显示
- c语言错误c2059 void,c2059(c语言错误代码c2059)
- 【云笔记9】Layui前端框架
- 基于国产芯片的刀片服务器,至强E5核心助力 5万左右刀片服务器导购
- LeetCode--704.二分查找(C++)
- Pytorch中的DDP
热门文章
- gge加MySQL_mysql分布式中间件cobar
- linux编程排序,Linux下简单的c编程——选择法排序
- configureWebpack与chainWebpack
- c语言追加字符串_Redis源码解析二--简单动态字符串
- linux 下nm命令输出,Linux nm命令介绍
- [CSS3] touch-action设置移动端拖动行为
- Linux引出环境变量的关键字,学习记录008-linux常用命令/设置系统and用户环境变量two(示例代码)...
- git 改了一段代码不想要了_想要壁纸不收费吗?简简单单用python代码实现
- Android的触摸监听器实现滑动图片
- wordpress修改mysql端口_Wordpress更改端口后访问自动跳转老端口