Git ignore 怎样只不追踪本地文件,也不删除远端的文件?

通常的git ignore都是自己本地的文件不再追踪,并且push之后会删除远端的这个文件。

我的需求是,本地文件不再追踪,也不删除远端的文件,否则远端仓库的代码就坏了,想想看,db.config文件从仓库中被删除是多可怕的事实。

阅读 6.3k
3 个回答

首先本地不追踪和远端仓库不删除这两者不能同时获得,因为git在每次提交时都是以快照的形式,而不是说提交了几个文件,所以说如果本地不追踪了,那么提交时肯定会默认删掉这个文件。

解决方案:这种问题很常见,跟node_modules要不要提交远端仓库等相似,你提到了一句话---“远端仓库的代码就坏了”,我需要纠正一下,并不是说git上面远端仓库的代码拿下来都是可以直接run的,百分之九十都是要改一些东西,配一些环境才可以work的,就比如我刚刚说的node_modules问题,没人会上传这么大的文件,只会上传一个 package.json文件,本地需要根据这个配置文件去配置本地信息。

你这个db.config文件也是一样的,你远端仓库上可以存一个db.config.default或者db.config.sample这样的文件,这里记录的是db.config文件的所有默认配置,但是每个人本地开发环境需要将db.config.default或者db.config.sample复制一份,重命名为db.config,然后将配置改为自己需要的,很有可能每个开发人员的本地配置都不一样,这时候把db.config加入.gitignore,一般来说.default或者.sample文件不需要改动提交的,除非是真的是整个项目需要修改才要提交

觉得麻烦或者配置文件多的话,可以写个脚本,用一些sed的命令就可以达到一键修改所有配置的效果,我一般都是这么做的,脚本里面把开debug、调php.ini里面扫描php文件变化的间隔时间等工作做了

你的需求可以做到,但是这不是问题。问题在于配置文件的管理。

我通常是这么做:不同环境不同的配置文件,config.xxx。不同的环境通过环境变量或者命令行参数或者软链接(到同一个名字,比如 config,这个文件不放到仓库里)来区分,加载相应的配置文件。

这个问题我遇到过。以一个test.txt文件为例,步骤如下:
1.把test.txt提交、推送到远端。
2.在.gitignore中添加test.txt。
3.本地执行:

git rm -r --cached .
git add .
git commit -m 'update .gitignore'

4.推送到远端。
查看一下,本地的test.txt已经被忽略了,别人的仓库正常跟踪test.txt。
.gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。那么解决方法就是先把本地缓存删除(改变成未track状态),然后再提交。
参考:
http://www.pfeng.org/archives...

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题