 
- Git - Home
- Git - Version Control
- Git - Basic Concepts
- Git - Command Line
- Git - Installation
- Git - First Time Setup
- Git - Basic Commands
- Git - Getting Help
- Git - Tools
- Git - Cheat Sheet
- Git - Terminology
- Git - Life Cycle
- Git - Get a Repository
- Git - Adding New Files
- Git - Recording Changes
- Git - Viewing Commit History
- Git Branching
- Git - Branches in a Nutshell
- Git - Creating a New Branch
- Git - Switching Branches
- Git - Branching and Merging
- Git - Merge Conflicts
- Git - Managing Branches
- Git - Branching Workflows
- Git - Remote Branches
- Git - Tracking Branches
- Git - Rebasing
- Git - Rebase vs. Merge
- Git - Squash Commits
- Git Operations
- Git - Clone Operation
- Git - Tagging Operation
- Git - Aliases Operation
- Git - Commit Operation
- Git - Stash Operation
- Git - Move Operation
- Git - Rename Operation
- Git - Push Operation
- Git - Pull Operation
- Git - Fork Operation
- Git - Patch Operation
- Git - Diff Operation
- Git - Status Operation
- Git - Log Operation
- Git - Head Operation
- Git - Origin Master
- Git Undoing
- Git - Undoing Changes
- Git - Checkout
- Git - Revert
- Git - Reset
- Git - Restore Operation
- Git - Rm
- Git - Switch Operation
- Git - Cherry-pick
- Git - Amend
- Git on the Server
- Git - Local Protocol
- Git - Smart HTTP Protocol
- Git - Dumb HTTP Protocol
- Git - The SSH Protocol
- Git - The Git Protocol
- Git - Getting Git on a Server
- Git - Setting up the Server
- Git - Daemon
- Git - GitWeb
- Git - GitLab
- Git - Third Party Hosted Options
- Distributed Git
- Git - Distributed Workflows
- Git - Contributing to a Project
- Git - Maintaining a Project
- Customizing Git
- Git - Configuration
- Git - Hooks
- Git - Attributes
- Git - Init
- Git - Commit
Git - Branch Tracking
In Git, a b>tracking branch is a local branch that is set up to track the state of a branch in a remote repository. When a local branch tracks a remote branch, Git allows you to easily sync the two branches.
Use simple commands like git pull and git push to bring in changes from or send your changes to the remote branch without explicitly specifying the remote branch each time.
When a branch is tracking a remote branch, Git will also inform you if your local branch is ahead of or behind the remote branch. This makes it easier to manage the flow of changes and maintain an up-to-date codebase.
How Branch Tracking Works
When you push a local branch to a remote repository for the first time, Git automatically sets up a tracking relationship between the local branch and the remote branch. The remote branch is often referred to as origin/branch-name, where origin is the default alias for the remote repository.
For example:
- You create a new branch called feature-branch on your local machine. 
- You push this branch to the remote repository using git push origin feature-branch. 
- Git sets up feature-branch to track origin/feature-branch. 
This point onwards, Git knows that feature-branchon the local machine corresponds to origin/feature-branch on the remote repository.
Setting Up a Tracking Branch
We can explicitly set up branch tracking when creating a new local branch or when we want to establish a relationship between an existing local branch and a remote branch. Let's look at how we can set up a tracking branch in different scenarios:
Creating a New Tracking Branch
When creating a new branch, we can set it to track a remote branch using the -u or --set-upstream-to option with the git branch or git checkout command.
git checkout -b feature-branch git push -u origin feature-branch
In this example:
- The -b option creates a new branch called feature-branch. 
- The -u option with git push sets up feature-branch to track origin/feature-branch. 
- From this point onward, git pull and git push will automatically synchronize changes between the local and remote branches. 
Tracking an Existing Branch
To set up a tracking relationship between an existing branch to a remote branch, you can use the following command:
git branch --set-upstream-to=origin/feature-branch feature-branch
This establishes the tracking relationship between the local feature-branch and the remote branch origin/feature-branch. Now, we can easily pull and push changes without specifying the remote branch each time.
Cloning a Repository and Tracking Branches
When you clone a remote repository using git clone, Git automatically sets up tracking for the default branch (usually main or master). For example, after cloning a repository, the local main branch will automatically track origin/main.
git clone https://github.com/user/repository.git
Checking Branch Tracking Status
We can view the current tracking relationships between the local and remote branches using several Git commands.
Viewing All Branches and Their Tracking Status
To see which local branches are tracking remote branches, along with their synchronization status, use the -vv option with the git branch command:
git branch -vv
This command lists all the local branches and shows which remote branch they are tracking. It also indicates whether the branch is ahead of or behind the remote branch. For example, we might see an output like this:
* main 123abc [origin/main: behind 2] Latest commit message feature-branch 456def [origin/feature-branch: ahead 1] Another commit message
This output tells you:
- The main branch is two commits behind origin/main. 
- The feature-branch is one commit ahead of origin/feature-branch. 
Viewing a Specific Branch's Tracking Status
To check whether a specific branch is tracking a remote branch, use the following command:
git status
Git will display a message indicating if your branch is tracking a remote branch, and whether it is ahead, behind, or up-to-date.
Syncing with Tracking Branches
Once a branch is tracking a remote branch, Git makes it easy to synchronize changes between the two using git pull and git push commands
Troubleshooting Branch Tracking Issues
There are a few common issues you might encounter when working with tracking branches, but they are usually easy to resolve.
Error: No Tracking Information
If we try to run git pull or git push on a branch that is not set up to track a remote branch, we might see an error like this:
fatal: The current branch feature-branch has no upstream branch.
o fix this, we can set the upstream branch using the --set-upstream-to option:
git branch --set-upstream-to=origin/feature-branch
Alternatively, we can set the upstream branch by using the -u option when pushing for the first time:
git push -u origin feature-branch
Ahead/Behind Status
If Git tells us that the branch is "ahead" or "behind" the remote branch, it means there are commits in one branch that the other branch doesn't have. We can fix this by running git pull to fetch and merge changes from the remote branch or git push to upload your local commits to the remote branch.