git删除提交历史

精准入口==>官方文档

Q:我们在提交代码时,把密码或者敏感信息也提交了,怎么办?

A:“在本地删除密码或敏感信息后,再push到远程仓库”

Q:"但这样删除后,在仓库的commit历史中,还是能看到密码呀?"

A:“那就删除commit历史, 但是怎么删呢。。。。”

B:"Using filter-branch"

首先,

进入到本地目录,执行 git filter-branch, 强制( --force) git对所有分支和tag的历史记录(--tag-name-filter cat -- -all)执行命令,

  但是不需要check out(--index-filter)这些历史记录.

执行的命令是 从历史记录中删除指定文件(git rm --cached --ignore-unmatch 文件名称)的内容和空提交(--prune-empty)

  如果删除的是目录,需使用(`git rm -r --cached --ignore-unmatch 目录名称`)

执行命令, 删除文件在本地的提交历史:

git filter-branch --force --index-filter 'git rm --cached --ignore-unmatch 文件' --prune-empty --tag-name-filter cat -- --all

然后,

(可选)把文件名加入到.gitignore文件中, 以后提交时,会被过滤掉,防止以后不小心又把敏感数据提交到代码仓库中

echo 文件名 >> .gitignore

git add 文件名

git commit -m "提交时忽略xxxx文件"
最后,

将修改提交到远程仓库,远程仓库的commit历史将被修改

git push origin --force --all

如果tag中也需要删除敏感数据,则执行

git push origin --force --tags

告诉同事, rebase 之前拉取的仓库, 不要merge, 因为merge后提交,会把之前清除的敏感文件又提交到仓库里。

  rebase 会先把本地提交的记录打补丁,然后把本地仓库更新成和远程相同,然后再应用补丁。

  merge 是合并, 本地已有的敏感数据还在,远端仓库没了。

摘自<git删除提交历史>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Git是目前最流行的版本管理系统,也是最先进的分布式版本控制系统(distributed version cont...
    pro648阅读 5,752评论 1 17
  • Add & Commit git init 初始化一个 Git 仓库(repository),即把当前所在目录变成...
    冬絮阅读 4,880评论 0 9
  • git常用命令 GIT常用命令备忘:http://stormzhang.com/git/2014/01/27/gi...
    新篇章阅读 8,541评论 1 26
  • 前几天发文章找不到合适的歌,朋友说你去听听朴树吧。 一听,便听了他十八年来所有的歌。 不多,三十多首,凑不够一场演...
    二喜的深夜食堂阅读 4,390评论 42 196
  • 生活总是有些出其不意,有时候你费尽心机却得不到,说不定就是在某个时间点,你想要解开的死结就突然通顺了。 我的朋友圈...
    艾薇00阅读 210评论 0 0