search
HomeDevelopment ToolsgitThe difference between 'git fetch' and 'git pull'

The difference between 'git fetch' and 'git pull'

Both git fetch and git pull can update the remote repository to the local one. So what are the differences between them? There are several concepts that have to be mentioned to clarify this issue.

FETCH_HEAD: is a version link, recorded in a local file, pointing to the end version of the branch that has been taken down from the remote warehouse.

commit-id: After each local work is completed, a git commit operation will be performed to save the current work to the local repo, and a commit-id will be generated at this time , which is a serial number that uniquely identifies a version. After using git push, this serial number will also be synchronized to the remote warehouse.

With the above concepts, let’s talk about git fetch

git fetch: This will update the latest commit-id of the branches contained in all remote warehouses in git remote. Record it into the .git/FETCH_HEAD file
The way git fetch updates the remote warehouse is as follows:

git fetch origin master:tmp 
//在本地新建一个temp分支,并将远程origin仓库的master分支代码下载到本地temp分支
git diff tmp 
//来比较本地代码与刚刚从远程下载下来的代码的区别
git merge tmp
//合并temp分支到本地的master分支
git branch -d temp
//如果不想保留temp分支 可以用这步删除

(1) If you use git fetch directly, the steps are as follows:

  • Create and update local remote branches. That is, create and update the origin/xxx branch, and pull the code to the origin/xxx branch.

  • Set the current branch-origin/current branch correspondence in FETCH_HEAD. If you directly git merge at that time, origin/abc can be merged into the abc branch.

(2) git fetch origin
Just manually specify the remote to fetch. When no branch is specified, it usually defaults to master

(3) git fetch origin dev
Specify remote remote and FETCH_HEAD, and only pull the commits of this branch.

This command will access the remote warehouse and pull all the data you don't have yet. Once the execution is complete, you will have references to all branches in that remote repository, which can be merged or viewed at any time.

If you use the git clone command to clone a warehouse, the command will automatically add it as a remote warehouse (git remote -v) and use "origin" as the abbreviation by default. So, git fetch origin will fetch all work newly pushed since the clone (or last fetch). It's important to note that the git fetch command will pull data into your local repository - it will not automatically merge or modify your current work. You must manually incorporate it into your job when ready.

If you have a branch set up to track a remote branch, you can use the git pull command to automatically fetch and merge the remote branch into the current branch. This may be an easier or more comfortable workflow for you; by default, the git clone command automatically sets the local master branch to track the cloned remote repository's master branch (or whatever the default branch is called). Running git pull will usually grab the data from the originally cloned server and automatically try to merge into the current branch.

git pull: First, based on the local FETCH_HEAD record, compare the local FETCH_HEAD record with the version number of the remote warehouse, and then git fetch obtains the subsequent version data of the remote branch currently pointed to. , and then use git merge to merge it with the local current branch. So it can be considered that git pull is a combination of the two steps of git fetch and git merge.

The usage of git pull is as follows:

git pull <远程主机名> <远程分支名>:<本地分支名>
//取回远程主机某个分支的更新,再与本地的指定分支合并。

Therefore, compared with git pull, git fetch is equivalent to getting the latest version from the remote to the local, but it will not automatically merge. If you need to selectively merge git fetch is a better choice. When the effect is the same, git pull will be faster.

Note: Using git pull to update the code is relatively simple and violent. However, based on the commit ID, their actual implementation principles are different, so don’t use git pull. Use git fetch and git merge to make it easier. Safety.

Recommended tutorial: "Git"

The above is the detailed content of The difference between 'git fetch' and 'git pull'. For more information, please follow other related articles on the PHP Chinese website!

Statement
This article is reproduced at:jb51. If there is any infringement, please contact admin@php.cn delete
Git and GitHub: What's the Relationship?Git and GitHub: What's the Relationship?Apr 14, 2025 am 12:10 AM

Git and GitHub are different tools: Git is software for version control, and GitHub is an online platform based on Git. 1.Git allows you to track file changes and collaborative development. 2. GitHub provides code hosting and collaboration tools to enhance team development efficiency.

GitHub: The Platform for Developers and ProjectsGitHub: The Platform for Developers and ProjectsApr 13, 2025 am 12:01 AM

The core features of GitHub include version control, branch management, code review, issue tracking and project management. 1. Version control and branch management are based on Git, allowing tracking of code changes and experimental development. 2. Code review is implemented through PullRequest to improve code quality and team collaboration. 3. Issues tracking and project management are carried out through Issues and the project management board to improve project transparency and traceability.

GitHub in Action: Examples and Use CasesGitHub in Action: Examples and Use CasesApr 12, 2025 am 12:16 AM

GitHub is a powerful tool to improve the efficiency and quality of software development. 1) Version control: manage code changes through Git. 2) PullRequests: Conduct code review and improve code quality. 3) Issues: Track bugs and project progress. 4) GitHubActions: Automate the construction, testing and deployment process.

Git vs. GitHub: Version Control and Code HostingGit vs. GitHub: Version Control and Code HostingApr 11, 2025 am 11:33 AM

Git is a version control system, and GitHub is a Git-based code hosting platform. Git is used to manage code versions and supports local operations; GitHub provides online collaboration tools such as Issue tracking and PullRequest.

What is Git in simple words?What is Git in simple words?Apr 09, 2025 am 12:12 AM

Git is an open source distributed version control system that helps developers track file changes, work together and manage code versions. Its core functions include: 1) record code modifications, 2) fallback to previous versions, 3) collaborative development, and 4) create and manage branches for parallel development.

Is Git the same as GitHub?Is Git the same as GitHub?Apr 08, 2025 am 12:13 AM

Git and GitHub are not the same thing. Git is a version control system, and GitHub is a Git-based code hosting platform. Git is used to manage code versions, and GitHub provides an online collaboration environment.

How to use GitHub for HTML?How to use GitHub for HTML?Apr 07, 2025 am 12:13 AM

The reason for using GitHub to manage HTML projects is that it provides a platform for version control, collaborative development and presentation of works. The specific steps include: 1. Create and initialize the Git repository, 2. Add and submit HTML files, 3. Push to GitHub, 4. Use GitHubPages to deploy web pages, 5. Use GitHubActions to automate building and deployment. In addition, GitHub also supports code review, Issue and PullRequest features to help optimize and collaborate on HTML projects.

Should I start with Git or GitHub?Should I start with Git or GitHub?Apr 06, 2025 am 12:09 AM

Starting from Git is more suitable for a deep understanding of version control principles, and starting from GitHub is more suitable for focusing on collaboration and code hosting. 1.Git is a distributed version control system that helps manage code version history. 2. GitHub is an online platform based on Git, providing code hosting and collaboration capabilities.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: How To Unlock Everything In MyRise
1 months agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

MantisBT

MantisBT

Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.