Git 能否实现两个 remote 自动配置不同的 ignore?

2017 年 7 月 14 日
 roccaplover
最近遇到一个我觉得还算常见的问题不知道怎么解决:本地有一个 git repo,我想每次 push 的时候提交一份不包含生产环境配置文件的到 GitHub 分享,同时把包含所有文件的 push 到生产环境服务器(即两个 remote 使用不同的 ignore 设置)

大家有什么好方案吗?
5477 次点击
所在节点    git
24 条回复
misaka19000
2017 年 7 月 14 日
开两个不同的 branch
340244120
2017 年 7 月 14 日
再开一个 repo,或者手动切换 ignore
roccaplover
2017 年 7 月 14 日
补充:我使用 Tower 来管理 git
ClassicOldSong
2017 年 7 月 14 日
开两个不同的 branch 吧,每次 merge 一下
mrcn
2017 年 7 月 14 日
都不加入版本控制,参考 Laravel 的.env 文件
一般来说环境配置这种东西很难有变动吧……
gccdchen
2017 年 7 月 14 日
如果你配置不是常变的话 , 为什么不弄一份 config.xml.sample , 把 config.xml 加入 ignore
crysislinux
2017 年 7 月 14 日
我们的配置文件都是单独写的,没在仓库里,仓库里一般放个配置文件的例子,比如 config.example.js 之类的
az422
2017 年 7 月 14 日
为什么不根据环境变量读取不同配置
roccaplover
2017 年 7 月 14 日
@mrcn 确实配置文件不常改, 这个方法可以。不过我觉得这个需求也还算常见吧,git 居然没有提供这方面的支持
yanhejihe
2017 年 7 月 14 日
@vencent git 是为了文件一致性,不同的 repo 文件不一样,那还得了
momocraft
2017 年 7 月 14 日
ignore 是在 commit 之前有效的, push 是之后
yanhejihe
2017 年 7 月 14 日
最近我也在用 git 部署,感觉有点问题,资源文件和代码混到一起了,感觉 git 直接用来部署不是很好。有谁做过的分享一下?
mooncakejs
2017 年 7 月 14 日
@yanhejihe submodule。
wsy2220
2017 年 7 月 14 日
配置文件用一个单独的 repo
middleware
2017 年 7 月 14 日
不同的 remote 不是用来区分不同的内容的。因为 Git 区分不同内容的唯一方式就是 SHA-1。所以还是老老实实的 branching 才对。对 Git 来说,不同的物理位置根本不是区分内容的依据。
shalk
2017 年 7 月 14 日
个人不推荐用 git push 来做部署,建议都保持一致,

根据环境不同,生效的配置文件不同;
或者用部署工具来处理;
andyL
2017 年 7 月 14 日
两个 ignore 不能取个并集吗
bombless
2017 年 7 月 14 日
建议配置直接 ignore 掉,不要放 repo 里面
crazystory
2017 年 7 月 14 日
配置文件忽略才是常见的,一般只保留配置模板不会保留具体的值
marvinwilliam
2017 年 7 月 14 日
需要放到 github 上的作为 git-submodule, 全部文件作为主项目,放到另外一个仓库

虽然 submodule 不是这么个用法,但应该可以满足你的需求....

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://v2ex.xtra.eu.org/t/375218

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX