Table of Contents
1. Submission node diagram
2. Actual git submission example
3. Recommended usage scenarios
Home Development Tools git What does git rebase mean?

What does git rebase mean?

Dec 29, 2021 pm 05:04 PM

git rebase means: redefining the repository status of the branch; when performing the rebase operation, git will extract the modifications on the branch to be rebased from the common ancestor of the two branches, and then rebase the branch to be rebased. The branch points to the latest commit of the base branch, and finally the changes just extracted are applied to the back of the latest commit of the base branch.

What does git rebase mean?

The operating environment of this tutorial: Windows 7 system, Git version 2.30.0, Dell G3 computer.

git rebase, as the name suggests, is to redefine (re) the starting point (base), that is, to redefine the repository status of the branch.

1. Submission node diagram

First, let’s feel what rebase is doing through a simple submission node diagram

Two branches, master and feature, where feature is at submission point B The branch pulled from master

has a new commit M on master, and two new commits C and D on feature

What does git rebase mean?
At this time, switch to the feature branch. Executing the following command is equivalent to merging the master branch into the feature branch

git checkout feature
git rebase master

//这两条命令等价于git rebase master feature
Copy after login

The following picture is the commit node diagram after rebasing. Explain its working principle:

What does git rebase mean?

  • feature: base branch to be changed, current branch
  • master: base branch, target branch

Official explanation: When performing a rebase operation, git will start from The common ancestor of the two branches begins to extract the modifications on the branch to be rebased, then points the branch to be rebased to the latest commit of the base branch, and finally applies the modifications just extracted to the back of the latest commit of the base branch.

Explanation with examples: When executing git rebase master on the feature branch, git will extract the modifications on the feature branch starting from the common ancestor B of master and featuer, that is, the two commits C and D, extract first arrive. Then point the feature branch to the latest commit of the master branch, which is M. Finally, the extracted C and D are connected to M, but this process is to delete the original C and D and generate new C’ and D’. Their submission content is the same, but the commit id is different. Naturally, feature eventually points to D’.

Popular explanation (important!) : rebase, rebase, can be directly understood as changing the base. The feature branch is a branch pulled from B of the master branch, and the base of feature is B. And if master has a new commit after B, it is equivalent to using the new commit on master as the new base of the feature branch. The actual operation is to save the submissions of the feature after B, then delete the original submissions, then find the latest submission location of the master, and then connect the saved submissions (new node with new commit id), so that the base of the feature branch is quite Yu became M instead of the original B.

There is also a very straightforward explanation. The key to the rebase command is actually to understand the "base". git rebase is to commit the difference between the base branch and the current branch (after the bifurcation point) ) is obtained, and then resubmit the differential submissions one by one after the latest submission point of the "base branch", and finally point the HEAD pointer of the current branch to the latest submission point


2. Actual git submission example

The submission record is constructed according to the above diagram, as shown in the following figure: (ABM is the master branch line, and ABCD is the feature branch line. Here, the master changes color and branches out. This does not affect understanding. It means two Just two lines per branch!)

What does git rebase mean?
At this time, execute git rebase master on the feature branch

After the rebase is completed, ABCD is the original feature branch line , ABMC'D' is the new feature branch line, ABM is the master branch line (no change)

What does git rebase mean?


There are so many things to do, but this is actually the most important thing. Different companies and situations have different usage scenarios, but in most cases the recommendations are as follows:

  • Use rebase when pulling the latest code from the public branch, that is, git pull -r or git pull -- Rebase, but one disadvantage is that after rebase, I don’t know which branch my current branch was first pulled from, because the base has changed. (If you use merge, there will be a meaningless commit record "Merge... to...")

  • When merging code on a public branch, use merge. (If you use rebase, then if other developers want to see the history of the main branch, it will not be the original history. The history has been tampered with by you)

Recommended study: "Git Tutorial

The above is the detailed content of What does git rebase mean?. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

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

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Hot Topics

Java Tutorial
1657
14
PHP Tutorial
1257
29
C# Tutorial
1230
24
How to update code in git How to update code in git Apr 17, 2025 pm 04:45 PM

Steps to update git code: Check out code: git clone https://github.com/username/repo.git Get the latest changes: git fetch merge changes: git merge origin/master push changes (optional): git push origin master

How to download git projects to local How to download git projects to local Apr 17, 2025 pm 04:36 PM

To download projects locally via Git, follow these steps: Install Git. Navigate to the project directory. cloning the remote repository using the following command: git clone https://github.com/username/repository-name.git

How to generate ssh keys in git How to generate ssh keys in git Apr 17, 2025 pm 01:36 PM

In order to securely connect to a remote Git server, an SSH key containing both public and private keys needs to be generated. The steps to generate an SSH key are as follows: Open the terminal and enter the command ssh-keygen -t rsa -b 4096. Select the key saving location. Enter a password phrase to protect the private key. Copy the public key to the remote server. Save the private key properly because it is the credentials for accessing the account.

How to return after git submission How to return after git submission Apr 17, 2025 pm 01:06 PM

To fall back a Git commit, you can use the git reset --hard HEAD~N command, where N represents the number of commits to fallback. The detailed steps include: Determine the number of commits to be rolled back. Use the --hard option to force a fallback. Execute the command to fall back to the specified commit.

How to check the warehouse address of git How to check the warehouse address of git Apr 17, 2025 pm 01:54 PM

To view the Git repository address, perform the following steps: 1. Open the command line and navigate to the repository directory; 2. Run the "git remote -v" command; 3. View the repository name in the output and its corresponding address.

Git vs. GitHub: Version Control and Code Hosting Git vs. GitHub: Version Control and Code Hosting Apr 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.

How to merge code in git How to merge code in git Apr 17, 2025 pm 04:39 PM

Git code merge process: Pull the latest changes to avoid conflicts. Switch to the branch you want to merge. Initiate a merge, specifying the branch to merge. Resolve merge conflicts (if any). Staging and commit merge, providing commit message.

What to do if the git download is not active What to do if the git download is not active Apr 17, 2025 pm 04:54 PM

Resolve: When Git download speed is slow, you can take the following steps: Check the network connection and try to switch the connection method. Optimize Git configuration: Increase the POST buffer size (git config --global http.postBuffer 524288000), and reduce the low-speed limit (git config --global http.lowSpeedLimit 1000). Use a Git proxy (such as git-proxy or git-lfs-proxy). Try using a different Git client (such as Sourcetree or Github Desktop). Check for fire protection

See all articles