• 怎么使用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远程删除某个历史提交记录”的内容就介绍到这里了,感谢大家的阅读。

  • 相关阅读:
    java计算机毕业设计红河旅游信息服务系统源码+数据库+系统+lw文档+mybatis+运行部署
    使用 Node.js 和 axios 模块编写登录脚本
    快速教程|如何在 AWS EC2上使用 Walrus 部署 GitLab
    02——go语言开发环境的搭建
    有一种浪漫,叫接触Linux
    赋能工业物联网 | 数据驱动,加速智能制造
    mysql只保留数字排序
    JPA+QueryDSL
    京东双11商品标题怎么写?教你打造优质标题
    汽车电子 -- CAN报文接收解析和发送组包
  • 原文地址:https://blog.csdn.net/qq_39162487/article/details/125547702