git提交记录删除
在开发中经常会遇到在本地测试的代码或者隐私信息,一不小心提交到了远程仓库,即便立即删除了再提交,但是上次的提交记录在远程依旧可以查看。 特别是像账号密码、key文件这种,很可能造成隐私泄露。### 一、删除最后一次提交
这种情况比较简单,主要操作分两步:
第一步:回滚上一次提交
`git reset --hard HEAD^`
第二步:强制提交本地代
`git push origin master -f`
由于本地reset之后本地库落后于远程几个版本,所以需要使用-f强制提交。
### 二、删除指定commit提交(非最后一次提交)
第一步:查看提交日志
`git reflog`
!(data/attachment/forum/202212/13/201954elxvrjrsr7n21fjx.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/300 "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保存退出。
!(data/attachment/forum/202212/13/203243fd3ttu577xudpurt.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/300 "image.png")
第三步:解决冲突,强制推送更新到远程
```bash
git add . # 冲突时使用
git commit -m "new commit"# 冲突时使用
git rebase --continue # 冲突时使用
git push origin master -f
```
明知没什么冲突或者问题需要处理的时候,直接git push origin master -f
页:
[1]