git强制回滚

git代码库回滚: 指的是将代码库某分支退回到以前的某个commit id

【本地代码库回滚】:

git reset --hard commit-id :回滚到commit-id,讲commit-id之后提交的commit都去除

git reset --hard HEAD~3:将最近3次的提交回滚

 

【远程代码库回滚】:

这个是重点要说的内容,过程比本地回滚要复杂

应用场景:自动部署系统发布后发现问题,需要回滚到某一个commit,再重新发布

原理:先将本地分支退回到某个commit,删除远程分支,再重新push本地分支

操作步骤:

1、git checkout the_branch

2、git pull

3、git branch the_branch_backup //备份一下这个分支当前的情况

4、git reset --hard the_commit_id //把the_branch本地回滚到the_commit_id

5、git push origin :the_branch //删除远程 the_branch

6、git push origin the_branch //用回滚后的本地分支重新建立远程分支

7、git push origin :the_branch_backup //如果前面都成功了,删除这个备份分支

如果使用了gerrit做远程代码中心库和code review平台,需要确保操作git的用户具备分支的push权限,并且选择了 Force Push选项(在push权限设置里有这个选项)

另外,gerrit中心库是个bare库,将HEAD默认指向了master,因此master分支是不能进行删除操作的,最好不要选择删除master分支的策略,换用其他分支。如果一定要这样做,可以考虑到gerrit服务器上修改HEAD指针。。。不建议这样搞

 

 

方法一:

 

1、新建backup分支 作为备份,以防万一

git branch backup 

2、将本地的backup分支 推送到远程的backup

git push origin backup:backup 

3、本地仓库彻底回退到xxxxx版本,xxxxx版本之后的commit信息将丢失

git reset --hard xxxxx 

4、删除远程的master分支 (注意master前有个:)

git push origin :master

主要远程仓库的master如果是保护分支将报错,请去掉对分支的保护设置:

remote: GitLab: You are  allowed  to  deleted protected branches from this project. To http://gitlab.mogujie.org/shihao/afanty.git ! [remote rejected] master (pre-receive hook declined) error: failed to push some refs to 'http://gitlab.mogujie.org/xxxx/xxxx.git'

5、重新创建远程master分支(这跟第1次提交本地代码库给远程仓库的命令一样)

git push origin master 

方法二:

1、本地代码回滚到上一版本(或者指定版本)

git reset --hard HEAD~1

2、加入-f参数,强制提交,远程端将强制跟新到reset版本

git push -f origin master 

转载https://blog.csdn.net/u013399759/article/details/52212436

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用IDEA中进行Git commit回滚时,可以通过以下步骤来完成: 1. 首先,在IDEA的Version Control面板中找到需要回滚的文件或项目。 2. 右键点击该文件或项目,选择"Git",然后选择"Show History",这将显示出该文件或项目的提交历史记录。 3. 在提交历史记录中,找到你想要回滚到的版本,并右键点击该版本。然后选择"Reset",再选择"Reset Current Branch to Here",这将开始回滚操作。 4. 在弹出的对话框中,选择回滚的方式。如果只想回滚到某个版本,而不将回滚的更改保存在工作目录中,可以选择"Soft"。这样,回滚将仅限于commit的信息,不会恢复到index file一级。如果还需要进行提交操作,直接commit即可。 5. 如果你需要强制推送回滚后的更改到远程分支,可以使用Git命令行或者在IDEA的Terminal中执行强制推送命令。例如,使用命令`git push origin <branch-name> --force`,其中`<branch-name>`是要推送的分支的名称。这将使本地代码与远程产生冲突,版本不一致,所以需要进行强制推送。 请注意,在执行Git回滚操作之前,请确保你已经备份好重要的更改,并且理解回滚操作的影响。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [idea中git版本回滚以及git指令回滚](https://blog.csdn.net/xenos2020/article/details/128933623)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [idea中git代码回滚](https://blog.csdn.net/weixin_46034322/article/details/129473341)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值