【.gitignore】:这个忽略文件会上传到远程仓库,会使所有人都按照这个文件规则忽略文件
【.git/info/exclude】:这个会关闭文件与远程仓库的跟踪,认为这个文件远程仓库是不会修改,所以每次pull都是本地的文件
【assume-unchanged】:这个会关闭文件与远程仓库的跟踪,认为这个文件远程仓库是不会修改,所以每次pull都是本地的文件
【skip-worktree】:这个不会关闭文件与远程仓库的跟踪,只是告诉Git不要跟踪对本地文件/文件夹的更改,每次pull时会拉取最新的变化会提示冲突,但因为没有跟踪本地更改,所以需要no-skip-worktree再合并最新的变化
以上在commit时都会忽略文件
附:
【skip-worktree】常用命令:
【skip-worktree】标记一个文件
git update-index --skip-worktree project-1.yml
git update-index --skip-worktree project-2.yml
获取被【skpi-worktree】标记的文件
git ls-files -v | grep -i "^S"
取消单个文件【skip-worktree】标记
git update-index --no-skip-worktree project-1.yml
git update-index --no-skip-worktree project-2.yml
批量取消文件【skip-worktree】标记
git ls-files -v | grep -i "^S" | cut -c 3- | tr '\012' '\000' | xargs -0 git
update-index --no-skip-worktree
批量取消代码解析:
git ls-files -v
显示所有文件的状态
grep -i ^S cut -c 3-
提取从第三个字符开始到结尾,去掉状态只保留路径
tr ‘\012’ ‘\000’
替换换行符 (\012) 为 (\000)
xargs -0 git update-index --no-skip-worktree
把以0分割的路径字符传给 git update-index --no-skip-worktree 取消
【assume-unchanged】常用命令
【assume-unchanged】标记一个文件
git update-index --assume-unchanged project-1.yml
git update-index --assume-unchanged project-2.yml
获取被【assume-unchanged】标记的文件
git ls-files -v | grep -I "^h"
取消单个文件【assume-unchanged】标记
git update-index --no-assume-unchanged project-1.yml
git update-index --no-assume-unchanged project-2.yml
批量取消文件【assume-unchanged】标记
git ls-files -v | grep -I "^h" | cut -c 3- | tr '\012' '\000' | xargs -0 git
update-index --no-assume-unchanged