[软件工具] git提交记录删除

问题记录 问题记录 10358 人阅读 | 0 人回复

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

一、删除最后一次提交

这种情况比较简单,主要操作分两步:

第一步:回滚上一次提交 git reset --hard HEAD^

第二步:强制提交本地代 git push origin master -f 由于本地reset之后本地库落后于远程几个版本,所以需要使用-f强制提交。

二、删除指定commit提交(非最后一次提交)

第一步:查看提交日志

git reflog image.png

获取要删除记录的前一次提交的提交ID 特别提示: rebase -i的ID一定是删除记录的前一次的提交ID

第二步:rebase操作 1 git rebase -i 1f48df2 执行完这个命令后,就可以看到 1f48df2后的所有 commit 记录。 默认是使用 vim 编辑器打开了commit log list

然后我们就可以针对我们不需要的某些 log 进行删除。 把原本的 pick 单词修改为 drop 就表示该ID对应的 commit log 我们需要删除。 vim保存退出。

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

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

明知没什么冲突或者问题需要处理的时候,直接git push origin master -f

关注下面的标签,发现更多相似文章
    黄小斜学Java

    疯狂的字节X

  • 目前专注于分享Java领域干货,公众号同步更新。原创以及收集整理,把最好的留下。
    包括但不限于JVM、计算机科学、算法、数据库、分布式、Spring全家桶、微服务、高并发、Docker容器、ELK、大数据等相关知识,一起进步,一起成长。
热门推荐
海康摄像头接入 wvp-GB28181-pro平台测试验
[md]### 简介 开箱即用的28181协议视频平台 `https://github.c
[CXX1300] CMake '3.18.1' was not
[md][CXX1300] CMake '3.18.1' was not found in SDK, PATH, or
[若依]微服务springcloud版新建增添加一个
[md]若依框架是一个比较出名的后台管理系统,有多个不同版本。