Heim > Fragen und Antworten > Hauptteil
Normalerweise verfolgt Git Ignore seine eigenen lokalen Dateien nicht mehr und die Remote-Datei wird nach dem Push gelöscht.
Meine Anforderung ist, dass lokale Dateien nicht mehr verfolgt werden und Remote-Dateien nicht gelöscht werden. Andernfalls wird der Code im Remote-Warehouse beschädigt. Denken Sie darüber nach, es ist schrecklich, dass die Datei db.config aus dem gelöscht wird Lager.
世界只因有你2017-05-25 15:10:28
首先本地不追踪和远端仓库不删除这两者不能同时获得,因为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文件变化的间隔时间等工作做了
过去多啦不再A梦2017-05-25 15:10:28
你的需求可以做到,但是这不是问题。问题在于配置文件的管理。
我通常是这么做:不同环境不同的配置文件,config.xxx。不同的环境通过环境变量或者命令行参数或者软链接(到同一个名字,比如 config,这个文件不放到仓库里)来区分,加载相应的配置文件。