使用 git 管理代码,开发分支和线上分支有不同文件,如何处理 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
git
Pro Git
Atlassian Git Tutorial
Pro Git 简体中文翻译
GitX
shiziwen
V2EX    git

使用 git 管理代码,开发分支和线上分支有不同文件,如何处理

  •  
  •   shiziwen 2015-11-13 19:06:23 +08:00 6061 次点击
    这是一个创建于 3650 天前的主题,其中的信息可能已经有所发展或是发生改变。

    在使用 git 进行代码管理时候,有开发分支 dev ,线上分支 pro 。

    在开发的时候,每个人会从 dev 分支上拉出自己的分支,进行开发,完成后合并到 dev 分支上面。
    线上环境进行更新的时候,会从 pro 分支上面 pull 最近的代码,然后重启服务运行。

    这里有一个问题, dev 分支和 pro 分支,往往会存在几个文件不同情况,例如配置文件 setting 等等。在这种情况下应该如何处理比较合适?

    如果 git 中不包含 setting 文件的话,如果配置文件需要更新的话,在线上环境就需要手动修改代码。

    请问大家是如何做的?结合 git 做到自动化部署和回退?

    多谢

    11 条回复    2016-03-23 10:55:47 +08:00
    raysmond
        1
    raysmond  
       2015-11-13 19:10:05 +08:00
    配置文件不是都区分出 setting-dev 和 setting-prod 不同的文件么?以及 prod 的配置文件为什么要放在 repository 中?各种配置不是放在服务器上单独的目录或环境变量中比较好么?
    cxbig
        2
    cxbig  
       2015-11-13 19:10:13 +08:00
    项目的自动化部署用 capistrano ,部署和回滚都很方便
    至于 settings ,方法有很多,可以用 capistrano 文件模板,或者直接放在 repo 以外的地方 link 进来
    lee015
        3
    lee015  
       2015-11-13 19:48:51 +08:00 via Android
    今天刚好也处理这个问题,我现在是这样:配置文件存两个如 config.php.devconfig.php.pro ,在具体环境复制一份去掉后缀,然后 gitignore config.php 。这样配置在 repo 里,也不相互影响。不过改了 repo 里配置要生效的话得手动再复制一份去后缀。
    HentaiMew
        4
    HentaiMew  
       2015-11-13 20:10:34 +08:00
    有些情况下,例如开发环境中的部署环境中有一些配置不一样,比如 zookeeper 的 ip 地址不同等。

    一般这种情况下,直接提交开发环境中的配置。在开发和部署(运行环境)之间有一个 CI 过程,例如 jenkins ,利用 CI 工具替换不同的配置文件。然后再部署。

    毕竟整个发布过程都是 CI 工具自动化做的,不需要人为干预。
    lightening
        5
    lightening  
       2015-11-13 20:32:16 +08:00
    你的自动化部署工具会管的吧……

    Capistrano, Docker 都可以 link 进其他的文件。
    ETiV
        6
    ETiV  
       2015-11-13 20:37:08 +08:00
    settings 复制一份成为 settings-example. 里面实际填的值改成 example 值

    .gitignore 增加 settings 文件名

    git 删掉 settings, 增加 settings-example

    线上部署前, cp settings-example settings
    编辑 settings 里的设置, 开跑
    cwek
        7
    cwek  
       2015-11-13 21:24:24 +08:00
    从同一个主线分开分支后,每个对应的配置文件改一次,以后不要乱后回去就是了。
    现在就是这样干。
    clino
        8
    clino  
       2015-11-13 21:29:04 +08:00
    把 settings 用另外一个 git 库管理起来然后 link 进去
    konakona
        9
    konakona  
       2015-11-13 21:39:43 +08:00
    Git Flow.
    msg7086
        10
    msg7086  
       2015-11-14 12:01:16 +08:00   1
    Rails 项目的话有自动部署可以用。
    很多系统都可以做约定优于配置,开发机上用约定参数,线上机器用配置参数就行了。
    比如 PHP 的话

    $database = 'xxx';
    $user = 'uuu';
    if (file_exists('config.php')) require_once('config.php');
    jakehu
        11
    jakehu  
       2016-03-23 10:55:47 +08:00
    好吧 我现在也遇到这个问题了 楼主最后怎么解决的?
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     922 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 25ms UTC 21:23 PVG 05:23 LAX 13:23 JFK 16:23
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86