Best workflow with Git & Github

后端 未结 5 960
天命终不由人
天命终不由人 2020-12-24 14:39

I\'m looking for some advice on how to properly structure the workflow for my team with Git & GitHub.

We are recent svn converts and it\'s kind of confusing how

相关标签:
5条回答
  • 2020-12-24 14:48

    Depending on your workflow, you can have a few 'important' branches on your central repository (ie. on github) which people can clone locally. These would correspond to 'stable', 'beta', 'development' etc. A nice article on a possible set of branches is this.

    Once that's done, you can let people use their own strategy. I prefer to keep topic branches for major projects and have one called 'quick-fixes' for quick things I need to do. If you have a team working on a major project which they want to keep on a separate branch cut off from the main repo, you can let them do it without any intervention. If people prefer having lots of tiny branches to try things out etc, they can do that too.

    As for automatically testing and integrating into production from staging, you can either configure the git hooks to do that or have a system running that will do it for you at regular intervals and report issues.

    0 讨论(0)
  • 2020-12-24 14:50

    You can copy your workflow from svn verbatim. Git can do everything svn can (but it can do more than that!). But your workflow could be improved in spite of CVS used.

    If you want to keep number of branches minimal (which in case you're new to git would in fact simplify things) in the workflow you have described I'd suggest to have (instead of one development branch) three per-developer branches: devel-john, devel-mary, etc:

    devel-john >--\
                   \
    devel-mary >------> staging ---> production
                   /
    devel-peter >-/
    

    This is convenient: all development changes would be pushed to central repository (which is often a good thing even for git) without conflicts and merged anytime by anyone who's willing/obliged to do the merging (for example into the staging branch).

    0 讨论(0)
  • 2020-12-24 14:50

    There are also some project workflows described in the ProGit book that show the Git commands developers will use to follow daily.

    There is a well regarded Git branching model described at http://nvie.com/git-model

    0 讨论(0)
  • 2020-12-24 14:58

    The ideas to keep in mind when working with a DVCS are:

    • distribution: even if you have one central GitHub, the developper are not limited to publish (push) only to that GitHub repo. They can fork the repo and publish in their own version (while fetching from the official central GitHub repo -- called "upstream").
      The advantage is they can rewrite history (reset, rebase --onto, rebase -i, ...) as many times as they want, in the end, they will make a pull request, allowing an integrator to manage their changes.

    • one of publication: in your own local repo, you can setup as many branches as you want (not one for every file modification, of course, but one for any new task or set of tasks you need to develop).
      But you can also set public branches that will be pushed ("published") to your remote repo.
      See this question on Git workflow, and also JC Hamano's articles on remote branches:
      o Fun with remote branches (1)
      o Fun with remote branches (2)
      The phrase "When people were confident with code they would commit and then merge it into the staging" should not apply with a DVCS: commit early, commit often, but push ("publish") only when you want.

    0 讨论(0)
  • 2020-12-24 15:00

    Great post on GitHub Workflow by one GitHub creators Scott Chacon and author of mentioned Pro Git book :P

    0 讨论(0)
提交回复
热议问题