Git-flow and master with multiple parallel release-branches

We are trying to adopt the successful Git branching model implemented by git-flow. Now, we are working on at least two release-branches, one for the latest stable release and one for the next (“preview”) release. What I don’t understand is why all releases seems to “linearized” to the master and tagged there. Why not tag the releases in their release branches? Why the master at all? Or why a develop branch and not use master for it?

  • git merge branches with different directory structures
  • Finding the SHA1's of all objects in a commit git
  • How do I export OpenVMS CMS history and import it to GIT
  • composer update not pulling latest dev-master
  • How to change a commit in common history?
  • Copy changes origin/development to origin/master
  • GitPython get commit for a file
  • Different versions of Git on Mac OS Yosemite
  • Check if there is a newer version of my local file in Github, with R
  • Manually extracting reflog when git reflog fails
  • Importing Subversion to GIT: problem with subpaths
  • Failed to clone repository on Windows 8
  • 5 Solutions collect form web for “Git-flow and master with multiple parallel release-branches”

    In the git-flow model, your “latest released” version actually maps to the master, while your “preview release” maps to a git-flow release branch. It is forked from develop and finally merged into master when the actual release happens. Then this will become your “latest release” and you will usually fix only bugs for that release, using git-flow hotfixbranches. In this way, your master always represents the most stable state of your latest released version.

    If you want to fix bugs for older releases or do any other develop there, you will fork a support branch from the appropriate commit in master (you will have all versions ever created there). support branches are still experimental (according to the docs) and are not well documented. But as you can see from the command line help:

    usage: git flow support [list] [-v]
           git flow support start [-F] <version> <base>
    

    these branches are just started and not intended to be merged back to master nor develop. This is usually fine, as fixes to “ancient” releases or features requested by customers to be implemented in “ancient” releases can’t or should not go back into master. If you still think, you want to port a fix to your main development line (represented by master and develop), just start a hotfix, cherry-pick your changes and finish the hotfix.

    Looks like mostly a mental model with a bit too much emphasis on branches. I agree, you could just tag the commits you release instead of merging them back into master.

    The picture is pretty, though. Merging everything back into master gives a clear indication of the releases in temporal order instead of having version tags strewn all over the graph.

    I think this model does not work for bugfixing in older releases, though. It messes up the neat ordering.

    1. Say we have released Version 1.0.1 and later added features and released 1.1.0.
    2. We discover a bug in 1.0.1 and want to fix it in both version
    3. We have to add 1.0.2 after 1.1.0 in master and then directly atfer (or before) also 1.1.1.

    To answer your question: I think this is a set of rules that makes for a simple mental model in some cases. Not all of the rules make sense from a purely technical point of view but that doesn’t make them bad. Mental models be good for ’em humanses.

    I personally think the mentioned git-flow is overcomplicated.

    If you are using GitHub try the GitHub flow (as described by Scott Chacon).

    It is especially useful for collaboration on multiple features, code-review and you could combine it with your Continuous Integration solution using the Commit Status API.

    UPDATE: There is a new official website of The GitHub Flow™

    UPDATE 2: There is a new official (and simplified) GitHub Guide for The GitHub Flow™: https://guides.github.com/introduction/flow/

    The master branch should ALWAYS represent your production code base, hence you always merge the code back to master right after a production release.

    Tagging is used to “memorize” the exact code which went into a production release so you can go back later and analyze the code if something went wrong.

    With this theoretically it shouldn’t matter if you tag your code on the release branch or on the master branch after you merged back to master. I personally prefer to tag the code on the release branch as this is exactly the code that went into the build/release (assuming something can go wrong with the merge).

    The issue with the development branch concept is that it is single threaded. Brendan in this thread mentioned a strategy which could be used involving a development branch concept.

    In my case, I have two version of the same software that the basics are the same but each version has some different features.

    So I create two worktree that means, create two relevant long-running branches beside the master.

    $git worktree add -b version-silver ..\version-silver master
    $git worktree add -b version-gold ..\version-gold master
    

    Then I have:

    $git branch
    master  # base stuff here
    version-silver # some normal features
    version-gold # some better features
    

    There is one repository, but I have 3 separate folders beside each other for each branch above. And make the common changes in master. then merge it with both other versions.

    cd master
    vim basic.cpp
    git add .
    git commit -m "my common edit on basic.cpp"
    cd ..\version-silver
    vim silver.cpp
    git add .
    git commit -m "my specific edit on silver.cpp"
    git merge master # here i get the basic.cpp latest changes for silver project
    cd ..\version-gold
    git merge master # here i get the basic.cpp latest changes for gold project
    

    Specific changes of each version will go in the corresponding folder as well, and the works on each project are isolated and IDE wouldn’t be confused.

    Hope that helps.

    Git Baby is a git and github fan, let's start git clone.