In git, "push -u" means to upload the local branch version to the remote merge, and record the default value of push to the remote branch; when adding the "-u" parameter, it means next time When continuing to push the remote branch, the push command can be abbreviated as "git push".
The operating environment of this article: Windows 10 system, Git version 2.30.0, Dell G3 computer.
What does push -u mean in git
The git push command is used to upload the local branch version to the remote and merge it.
Generally, the git push command is used when pushing a local warehouse to a remote warehouse. As a novice, I saw some tutorials on the Internet. Some of them will bring a -u parameter when git push, while some do not. There is no difference in the actual results of the push. I'm just curious about what the -u parameter does?
After searching for a while, I summarized and recorded some of everyone’s explanations and analyses.
Parameter analysis:
First of all, for git push, there is this description:
-u
–set -upstream
For every branch that is up to date or successfully pushed, add upstream (tracking) reference, used by argument-less git-pull(1) and other commands. For more information, see branch.< ;name>.merge in git-config(1).
In this description, you can see that the -u parameter is related to the following variable
branch.< ;name>.merge
branch.
And upstream refers to the main repository that others will pull from, such as your GitHub repository. The -u option automatically sets upstream for you, linking your repository to a central repository. This way, in the future Git will "know" where you want to push to and where you want to pull from, so you can use git pull or git push without parameters.
When you git pull from a branch without specifying the source remote or branch, git looks at the branch.
To put it simply, bringing the -u parameter is actually equivalent to recording the default value of push to the remote branch, so that next time we want to continue pushing the remote branch The push command can be abbreviated as git push.
Example display:
An example is shown below to illustrate this point.
andy@AndyMacBookPro:/usr/local/github/andy/php-examples$ git pull There is no tracking information for the current branch. Please specify which branch you want to merge with. See git-pull(1) for details. git pull <remote> <branch> If you wish to set tracking information for this branch you can do so with: git branch --set-upstream-to=origin/<branch> test
This is the result if you have not used the -u parameter before and later omitted the branch parameters you want to pull. Pull because there is no track for the current branch. So it does not know where you want to pull from, so this is the meaning of the -u parameter, specifying the trach branch.
In fact, after specifying -u, you can go to .git/config to view the GIT configuration file. You can see the record of the branch "test" below:
[branch "master"] remote = origin merge = refs/heads/master [branch "test"] remote = origin merge = refs/heads/test
This way git Only then can you know the remote and merge information under the current test. If you do not bring in the -u parameter when git push, then there will be no branch "test" item in the config.
[branch "master"] remote = origin merge = refs/heads/master
Configuration instructions, this tells Git 2 things:
When you are on the master branch, the default remote is origin.
When used on a git pullmaster branch (no remote and branch specified), use the default remote (source) and merge changes from the remote master branch.
Configuration modification
You can manually go to .git/config to modify the contents of the GIT configuration file, or you can use the command line to set these options.
$ git config branch.master.remote origin $ git config branch.master.merge refs/heads/master
If you use commands to configure, it will have certain error correction capabilities. For example, you typed a branch that does not exist or you did not perform the git remote add operation. In newer git, I hope you use git branch --set-upstream-to=origin/master master
In fact, executing the command git push -u origin master with the -u parameter added is equivalent to executing
git push origin master and
git branch --set-upstream master origin/master.
So, if you are pushing code to a remote branch and want to continue pushing to the remote branch, you can add the -u parameter to the push command to simplify the subsequent push command input.
Recommended learning: "Git Tutorial"
The above is the detailed content of What does push -u mean in git. For more information, please follow other related articles on the PHP Chinese website!

The role and function of Git and GitHub in software development is to manage code and collaborative development. Git efficiently manages code versions through commit, branch and merge functions, while GitHub provides code hosting and collaboration tools such as PullRequest and Issues to improve team collaboration efficiency.

GitHub is the preferred platform for developers to discover, share and contribute code. 1) Find specific code bases through search functions, such as Python projects. 2) Create a repository and push code to share with developers around the world. 3) Participate in open source projects and contribute code through Fork and PullRequest.

Git is a version control system, and GitHub is an online platform based on Git. The steps to using Git and GitHub for code management and team collaboration include: 1. Initialize the Git repository: gitinit. 2. Add files to the temporary storage area: gitadd. 3. Submit changes: gitcommit-m"Initialcommit". 4. Related to the GitHub repository: gitremoteaddoriginhttps://github.com/username/repository.git. 5. Push code to GitHub: gitpush-uoriginmaste

GitHub has a far-reaching impact on software development and collaboration: 1. It is based on Git's distributed version control system, which improves code security and development flexibility; 2. Through functions such as PullRequest, it improves team collaboration efficiency and knowledge sharing; 3. Tools such as GitHubActions help optimize the development process and improve code quality.

The methods of sharing, managing and contributing code on GitHub include: 1. Create a repository and push code, and write README and LICENSE files; 2. Use branches, tags and merge requests to manage code; 3. Fork the repository, modify and submit PullRequest contribution code. Through these steps, developers can effectively use GitHub to improve development efficiency and collaboration capabilities.

Git is a distributed version control system, and GitHub is a Git-based collaboration platform. Git is used for version control and code management, while GitHub provides additional collaboration features such as code review and project management.

Git is a distributed version control system, and GitHub is an online platform based on Git. Git is used for version control, branch management and merger, and GitHub provides code hosting, collaboration tools and social networking capabilities.

Git is a back-end version control system, and GitHub is a front-end collaboration platform based on Git. Git manages code version, GitHub provides user interface and collaboration tools, and the two work together to improve development efficiency.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

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

Hot Article

Hot Tools

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

SublimeText3 Chinese version
Chinese version, very easy to use

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

Dreamweaver Mac version
Visual web development tools
