修改.gitignore后不生效
1.问题背景
项目有一些开发时用的配置文件,需要用到所以不能删,但是却不想提交改动。
理所当然地想到将它加入 .gitignore
规则中,但是我的改动还是被 git
被捕捉到了,为啥呢?
gitignore - Specifies intentionally untracked files to ignore
官方文档给出了标准答案,原来 .gitignore
只对未跟踪的文件起作用!
已跟踪的文件是指那些被纳入了版本控制的文件,在上一次提交中有它们的记录。那么未跟踪文件就是指那些从没提交过的文件。
因为我之前已经使用提交过了,所以.gitignore
也救不了我 。
那我现在已经覆水难收的情况下,想要忽略 index.scss 该怎么做?
2.解决方案
我与 git 的对话
【我】:我的目的是在仓库里面保留 index.scss,但是要所有人忽略它的改动。你能做到吗?
【git】:我做不到,我是个版本控制的仓库,我要为所有文件的版本负责,而不是你存储文件的中转站!但是你可以这样:
- 别让我管理你的 index.scss,踢出我的版本控制,存在自个儿的电脑里。
- 暂时只忽略你的文件改动,别人已加到版本库的文件改动,你可管不着。
让我们来看看根据 git 提供的思路,如何实践。
(1)取消跟踪,删除远程文件(推荐)
你要做的
- 先将 src/index.scss 加入
.gitignore
文件。 - 再执行以下命令:
git rm -r --cached .
git add .
git commit -m "update gitignore"
在你的电脑进行以上操作后,index.scss 正式脱离了版本管理的管制。git rm --cached
会保留你本机的文件,但是会从版本库里面删除。
其他电脑要做的
git pull
- 将 index.scss 加回来
因为其他主机(您同事的电脑等等)在 git pull
你以上的改动时,index.scss 会被删除,所以 index.scss 需要加回来。
可以手动加回来,也可以使用构建工具初始化自动生成 index.scss 文件。
(2)暂时忽略已跟踪文件的变更,不删除远程文件(不推荐)
你要做的
git update-index --assume-unchanged src/index.scss
其他电脑要做的
git update-index --assume-unchanged src/index.scss
git update-index
为一个单独文件创建暂存区,--assume-unchanged
通知 git 不要再监控这个文件的改动了。
合起来的意思是:我单独把你拎出来,暂时先跟踪你。因为命令只对当前工作区生效,同理其他主机也要进行同样的操作。
为什么推荐方案(1)不推荐方案(2)?
方案(2)非常纯粹,一招鲜吃遍天。
但是它容易出错,如果某个同事忘记执行这条指令,将 index.scss 提交到了版本库, 那么其他人都需要一起——重新执行命令,再次让版本库忽略 index.scss。
过来人告诉你,这方法真的不好维护。
使用方案(1),因为文件已经删了,且已经将其加入到了 .gitignore
,后续的提交都不会跟踪这份新的 index.scss 文件。同事忘不忘记操作也只是影响他自己,而且只需一次操作,无后顾之忧。
资料
来源:https://zhuanlan.zhihu.com/p/270144760