www.atlassian.com
Open in
urlscan Pro
185.166.143.5
Public Scan
URL:
https://www.atlassian.com/git/tutorials/comparing-workflows/gitflow-workflow
Submission: On November 19 via api from US — Scanned from NL
Submission: On November 19 via api from US — Scanned from NL
Form analysis
2 forms found in the DOM<form class="newsletter">
<input class="is-empty _input" type="email" placeholder="Enter Your Email For Git News">
<button type="submit" class="_status icon-email-submit">Submit</button>
</form>
<form class="newsletter">
<input class="is-empty _input" type="email" placeholder="Enter Your Email For Git News">
<button type="submit" class="_status icon-email-submit">Submit</button>
</form>
Text Content
Learn Git Learn Git with Bitbucket Cloud Create a Git repository Copy your Git repository and add files Pull changes from your Git repository on Bitbucket Cloud Use a Git branch to merge a file Learn about code review in Bitbucket Cloud Create a repository Clone and make a change on a new branch If you're using command line If you're using Sourcetree Create a pull request to merge your change Learn branching in Bitbucket Cloud Get set up Review branching workflow Learn undoing changes with Bitbucket Cloud git status git log git reset git revert Beginner What is version control Benefits of version control Source Code Management What is Git Performance Security Flexibility Version control with Git Why Git for your Organization Git for developers Git for marketing Git for product management Git for designers Git for customer support Git for human resources Git for anyone managing a budget Install Git Install Git on Mac OS X Install Git on Windows Install Git on Linux Git SSH Git archive GitOps Git Cheatsheet Getting Started Setting up a repository git init git clone git config git alias Saving changes git add git commit git diff git stash .gitignore Inspecting a repository git status git tag git blame Undoing changes git checkout git clean git revert git reset git rm Rewriting history git commit --amend git rebase git rebase -i git reflog Collaborating Syncing git remote git fetch git push git pull Making a Pull Request How it works Example Where to go from here Using branches git branch git checkout git merge Merge conflicts Merge strategies Comparing workflows Centralized Workflow Feature Branch Workflow Gitflow Workflow Forking Workflow Migrating to Git SVN to Git - prepping for the migration For administrators Basic Git commands Git Migration Tools For developers Migrate to Git from SVN Prepare Convert Synchronize Share Migrate Perforce to Git - why to make the move Migrating from Perforce to Git How to move a Git repository with history Advanced Tips Advanced Git Tutorials Merging vs. Rebasing Conceptual Overview The Golden Rule of Rebasing Workflow Walkthrough Summary Resetting, Checking Out, and Reverting Advanced Git log Formatting Log Output Filtering the Commit History Summary Git Hooks Conceptual Overview Local Hooks Server-side Hooks Summary Refs and the Reflog Hashes Refs Packed Refs Special Refs Refspecs Relative Refs The Reflog Summary Git submodules Git subtree Large repositories in Git Git LFS Git gc Git prune Git Bash How to store dotfiles Git Cherry Pick GitK Git-show Home TUTORIALS Tutorials Articles Glossary Tutorials Submit Sign up Search Search GITFLOW WORKFLOW Gitflow is a legacy Git workflow that was originally a disruptive and novel strategy for managing Git branches. Gitflow has fallen in popularity in favor of trunk-based workflows, which are now considered best practices for modern continuous software development and DevOps practices. Gitflow also can be challenging to use with CI/CD. This post details Gitflow for historical purposes. WHAT IS GITFLOW? Giflow is an alternative Git branching model that involves the use of feature branches and multiple primary branches. It was first published and made popular by Vincent Driessen at nvie. Compared to trunk-based development, Giflow has numerous, longer-lived branches and larger commits. Under this model, developers create a feature branch and delay merging it to the main trunk branch until the feature is complete. These long-lived feature branches require more collaboration to merge and have a higher risk of deviating from the trunk branch. They can also introduce conflicting updates. Gitflow can be used for projects that have a scheduled release cycle and for the DevOps best practice of continuous delivery. This workflow doesn’t add any new concepts or commands beyond what’s required for the Feature Branch Workflow. Instead, it assigns very specific roles to different branches and defines how and when they should interact. In addition to feature branches, it uses individual branches for preparing, maintaining, and recording releases. Of course, you also get to leverage all the benefits of the Feature Branch Workflow: pull requests, isolated experiments, and more efficient collaboration. GETTING STARTED Gitflow is really just an abstract idea of a Git workflow. This means it dictates what kind of branches to set up and how to merge them together. We will touch on the purposes of the branches below. The git-flow toolset is an actual command line tool that has an installation process. The installation process for git-flow is straightforward. Packages for git-flow are available on multiple operating systems. On OSX systems, you can execute brew install git-flow. On windows you will need to download and install git-flow. After installing git-flow you can use it in your project by executing git flow init. Git-flow is a wrapper around Git. The git flow init command is an extension of the default git init command and doesn't change anything in your repository other than creating branches for you. HOW IT WORKS DEVELOP AND MAIN BRANCHES Instead of a single main branch, this workflow uses two branches to record the history of the project. The main branch stores the official release history, and the develop branch serves as an integration branch for features. It's also convenient to tag all commits in the main branch with a version number. The first step is to complement the default main with a develop branch. A simple way to do this is for one developer to create an empty develop branch locally and push it to the server: git branch develop git push -u origin develop This branch will contain the complete history of the project, whereas main will contain an abridged version. Other developers should now clone the central repository and create a tracking branch for develop. When using the git-flow extension library, executing git flow init on an existing repo will create the develop branch: $ git flow init Initialized empty Git repository in ~/project/.git/ No branches exist yet. Base branches must be created now. Branch name for production releases: [main] Branch name for "next release" development: [develop] How to name your supporting branch prefixes? Feature branches? [feature/] Release branches? [release/] Hotfix branches? [hotfix/] Support branches? [support/] Version tag prefix? [] $ git branch * develop main FEATURE BRANCHES Each new feature should reside in its own branch, which can be pushed to the central repository for backup/collaboration. But, instead of branching off of main, feature branches use develop as their parent branch. When a feature is complete, it gets merged back into develop. Features should never interact directly with main. Note that feature branches combined with the develop branch is, for all intents and purposes, the Feature Branch Workflow. But, the Gitflow workflow doesn’t stop there. Feature branches are generally created off to the latest develop branch. CREATING A FEATURE BRANCH Without the git-flow extensions: git checkout develop git checkout -b feature_branch When using the git-flow extension: git flow feature start feature_branch Continue your work and use Git like you normally would. FINISHING A FEATURE BRANCH When you’re done with the development work on the feature, the next step is to merge the feature_branch into develop. Without the git-flow extensions: git checkout develop git merge feature_branch Using the git-flow extensions: git flow feature finish feature_branch RELEASE BRANCHES Once develop has acquired enough features for a release (or a predetermined release date is approaching), you fork a release branch off of develop. Creating this branch starts the next release cycle, so no new features can be added after this point—only bug fixes, documentation generation, and other release-oriented tasks should go in this branch. Once it's ready to ship, the release branch gets merged into main and tagged with a version number. In addition, it should be merged back into develop, which may have progressed since the release was initiated. Using a dedicated branch to prepare releases makes it possible for one team to polish the current release while another team continues working on features for the next release. It also creates well-defined phases of development (e.g., it's easy to say, “This week we're preparing for version 4.0,” and to actually see it in the structure of the repository). Making release branches is another straightforward branching operation. Like feature branches, release branches are based on the develop branch. A new release branch can be created using the following methods. Without the git-flow extensions: git checkout develop git checkout -b release/0.1.0 When using the git-flow extensions: $ git flow release start 0.1.0 Switched to a new branch 'release/0.1.0' Once the release is ready to ship, it will get merged it into main and develop, then the release branch will be deleted. It’s important to merge back into develop because critical updates may have been added to the release branch and they need to be accessible to new features. If your organization stresses code review, this would be an ideal place for a pull request. To finish a release branch, use the following methods: Without the git-flow extensions: git checkout main git merge release/0.1.0 Or with the git-flow extension: git flow release finish '0.1.0' HOTFIX BRANCHES Maintenance or “hotfix” branches are used to quickly patch production releases. Hotfix branches are a lot like release branches and feature branches except they're based on main instead of develop. This is the only branch that should fork directly off of main. As soon as the fix is complete, it should be merged into both main and develop (or the current release branch), and main should be tagged with an updated version number. Having a dedicated line of development for bug fixes lets your team address issues without interrupting the rest of the workflow or waiting for the next release cycle. You can think of maintenance branches as ad hoc release branches that work directly with main. A hotfix branch can be created using the following methods: Without the git-flow extensions: git checkout main git checkout -b hotfix_branch When using the git-flow extensions: $ git flow hotfix start hotfix_branch Similar to finishing a release branch, a hotfix branch gets merged into both main and develop. git checkout main git merge hotfix_branch git checkout develop git merge hotfix_branch git branch -D hotfix_branch $ git flow hotfix finish hotfix_branch EXAMPLE A complete example demonstrating a Feature Branch Flow is as follows. Assuming we have a repo setup with a main branch. git checkout main git checkout -b develop git checkout -b feature_branch # work happens on feature branch git checkout develop git merge feature_branch git checkout main git merge develop git branch -d feature_branch In addition to the feature and release flow, a hotfix example is as follows: git checkout main git checkout -b hotfix_branch # work is done commits are added to the hotfix_branch git checkout develop git merge hotfix_branch git checkout main git merge hotfix_branch SUMMARY Here we discussed the Gitflow Workflow. Gitflow is one of many styles of Git workflows you and your team can utilize. Some key takeaways to know about Gitflow are: * The workflow is great for a release-based software workflow. * Gitflow offers a dedicated channel for hotfixes to production. The overall flow of Gitflow is: 1. A develop branch is created from main 2. A release branch is created from develop 3. Feature branches are created from develop 4. When a feature is complete it is merged into the develop branch 5. When the release branch is done it is merged into develop and main 6. If an issue in main is detected a hotfix branch is created from main 7. Once the hotfix is complete it is merged to both develop and main Next, learn about the Forking Workflow or visit our workflow comparison page. Ready to learn Git? Try this interactive tutorial. Get started now NEXT UP: FORKING WORKFLOW Start next tutorial POWERED BY RECOMMEND WANT FUTURE ARTICLES? Submit SITE HOSTED BY creativecommons.orgExcept where otherwise noted, all content is licensed under a Creative Commons Attribution 2.5 Australia License. This site uses cookies to improve your browsing experience, perform analytics and research, and conduct advertising. To change your preferences, click Cookie Settings. Otherwise, clicking Accept all Cookies indicates you agree to our use of cookies on your device.Atlassian Cookies and Tracking Notice > Cookie Settings Accept All Cookies