常青树 发表于 2018-1-15 20:35:10

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 是合并, 本地已有的敏感数据还在,远端仓库没了。
页: [1]
查看完整版本: git删除提交历史