Skip to main content
18 of 25
Combine "git fetch" explanation into single paragraph.
Mateen Ulhaq
  • 28.1k
  • 22
  • 122
  • 157

In the simplest terms, git pull does a git fetch followed by a git merge.

You can do a git fetch at any time to update your remote-tracking branches under refs/remotes/<remote>/. This operation never changes any of your own local branches under refs/heads, and is safe to do without changing your working copy. I have even heard of people running git fetch periodically in a cron job in the background (although I wouldn't recommend doing this).

A git pull is what you would do to bring a local branch up-to-date with its remote version, while also updating your other remote-tracking branches.

From the Git documentation for git pull:

In its default mode, git pull is shorthand for git fetch followed by git merge FETCH_HEAD.

Greg Hewgill
  • 1.0m
  • 193
  • 1.2k
  • 1.3k