• 怎么使用Git远程删除某个历史提交记录


    这篇文章主要介绍“怎么使用Git远程删除某个历史提交记录”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么使用Git远程删除某个历史提交记录”文章能帮助大家解决问题。

    引言
    在开发中经常会遇到在本地测试的代码或者隐私信息,一不小心提交到了远程仓库,即便立即删除了再提交,但是上次的提交记录在远程依旧可以查看。 特别是像账号密码、key文件这种,很可能造成隐私泄露。
    在这里插入图片描述
    分两种情况:

    一、删除最后一次提交
    这种情况比较简单,主要操作分两步:

    第一步:回滚上一次提交

    git reset --hard HEAD^
    
    • 1

    第二步:强制提交本地代码

    git push origin master -f
    
    • 1

    由于本地reset之后本地库落后于远程几个版本,所以需要使用-f强制提交。

    二、删除指定commit提交(非最后一次提交)
    假定: 现在我们要删除commit–2这条提交记录

    图例
    在这里插入图片描述
    第一步:查看提交日志,获取要删除记录commit–2的前一次提交commit–1的提交ID
    特别提示: rebase -i的ID一定是删除记录的前一次的提交ID

    git reflog
    
    • 1

    展示如下内容:

    b08ec3f HEAD@{4}: commit: commit--3
    39841d1 HEAD@{5}: commit: commit--2
    35f96e1 HEAD@{6}: commit: commit--1
    
    • 1
    • 2
    • 3

    拿到对应的提交ID为35f96e1

    第二步:rebase操作

    git rebase -i 35f96e1
    
    • 1

    执行完这个命令后,就可以看到 35f96e1 后的所有 commit 记录。如下图
    默认是使用 vim 编辑器打开了commit log list。然后我们就可以针对我们不需要的某些 log 进行删除。
    把原本的 pick 单词修改为 drop 就表示该ID对应的 commit log 我们需要删除。
    vim保存退出。
    在这里插入图片描述

    第三步:解决冲突,强制推送更新到远程

    git add .                   # 冲突时使用
    git commit -m "new commit"  # 冲突时使用
    git rebase --continue       # 冲突时使用
    git push origin master -f
    
    • 1
    • 2
    • 3
    • 4

    再查看远程的提交记录,发现commit–2就没有了。

    关于“怎么使用Git远程删除某个历史提交记录”的内容就介绍到这里了,感谢大家的阅读。

  • 相关阅读:
    Go基础语法:list
    springboot 接入 logback.xml 彻底搞出一个超级完整加注释的版本-可在生产环境直接使用
    朴素贝叶斯法\贝叶斯分类器举例说明
    idea springboot 如何搭建多层子模块
    大富豪3(GM商城版)新手攻略之购买土地
    LandingSite电子标签Quuppa固件进入DFU状态说明
    HTML <table> <tr> <td> caption colspan ,rowspan, thead, tbody,tfoot
    攻防世界WEB练习-Fakebook
    Python学习第九篇:zipfile 库操作压缩包
    C语言--指针与数组--遍历数组的n种方式【详细】
  • 原文地址:https://blog.csdn.net/qq_39162487/article/details/125547702