Quite often when using git, you only need to use one remote:
origin
. All your pushes and pulls communicate with this one
host. However, there are many occasions when using multiple Git remotes
is incredibly handy.
Quick Overview: Remotes
If you haven’t already, I strongly recommend that you check out these two Git resources in your free time:
- Learn Git Branching, an interactive walkthrough of some powerful Git features
- A Hacker’s Guide to Git, an explanation of Git by “taking a peek under the hood”
In this article, I’ll only be talking about remotes. Remotes are basically “mirrors” of a branch that you have locally, but on a different computer.
Scenario: Working with Code in 15-150
At CMU, the class 15-150 distributes its starter code in a beautiful way: using Git! This opens up a number of things we can take advantage of, but there’s one thing in particular we can do using multiple git remotes.
In 15-150, the code is distribute in a read-only Git repo. If we want a place where we can push and pull our changes, we’ll need to create our own bare repo (a repo that’s used just for pushing and pulling). You’ll note that I said push and pull. The reason why I want to be able to pull is because I want to have 2 clones of this repo: one on the CMU Andrew Unix servers (where the 15-150 code is hosted), and one on my laptop, where there’s no network latency to edit files in Vim.
To achieve this setup, the first thing we’ll do is set up the bare repo. The best place to put a bare repo is on a server so that you can always access your code. So from Andrew, I’ll run the commands:
This creates a bare repo initialized with all the 15-150 content which I can clone in two different ways: one for if I’m on Andrew, one if I’m on my laptop.
To throw in a few graphics, our setup looks like this right now:
I’m representing bare repos as clouds and clones of those repos as squares, with arrows representing whether code can flow from one place to the next. As you can see, to send code back and forth between Andrew and my laptop, I can just push in one place and pull in the other.
The one thing missing from our picture is the original handout repo. How will we get updates as the homeworks are released? The last piece involves setting this up.
Once we run those two lines, our setup looks like this, where arrows point in the direction data can flow:
After this, we’re able to run git pull upstream master
to get the 15-150 starter code as it’s released. I find this model
particularly useful for all my classes, even the ones that don’t
distribute their code using Git. Having code both on Andrew and on my
local machine is a generally handy configuration, and using Git to push
the code around to the right places makes my workflow simple.
As always, let me know if something was unclear or incorrect in the comments!
More Applications
There are plenty other applications of using multiple remotes with Git. Perhaps the most common is to use them with the GitHub forking model, which is useful when collaborating on a software development project with others. You can use multiple remotes to do things like resolve merge conflicts in pull requests and to keep your fork up to date with the original repo.