preface
Git is a version control tool. There are three main benefits of version control:
-
Roll back the current version to any version
-
Viewing the Historical Version
-
Compare the differences between the two versions
git
Related terms
Amend modify merge Merge Conflict Conflict Origin Source upstream Upstream downstream Verbose Details ReFLOg Refer to the logCopy the code
Git basis
-
Modified: The project has not been committed to the local database, i.e., no Git add
-
Staged: Staged, when git add was executed but no Git commit was made
-
Committed: Committed to the local database
Basic Git workflow
- Write the code
- Take a snapshot of the modified file and save it to the staging area
- Commit the code to upload a snapshot of the files in the staging area to Git
The basic configuration
To view the current Git configuration:
git config --list
git config user.name
git config user.email
// Learn more about git configuration queries with git config -h
Copy the code
Modify the current configuration (generally, it only needs to be configured once, but if the computer is changed, or the system is changed, we need to reconfigure) :
// User name configuration
git config --global user.name "xiaohuochai"
// Email configuration
git config --global user.email "[email protected]"
Copy the code
Project configuration. Gitignore
When we commit a project to Git, there are many files that do not need to be submitted, such as node_modules,.vscode,.idea, etc
This is the.gitignore file we need to create in the root of the project
node_modules/
/*/node_modules/
.idea
.vscode
Copy the code
Configure SSH
When we pull and push code from a remote github server, how do we verify who is committing and pulling the code? In order to avoid the trouble of entering the user name and password every time, we can configure SSH to solve the problem.
To view SSH on the host:
SSH // Open the command line CD ~/. SSH // Go to the corresponding directory ls // If yes, you can find the private key id_rsa file and the public key id_rsa.pub cat id_rsa.pub or vim id_rsa.pub // View the file contentCopy the code
If not, we can generate it with the following command
ssh-keygen
Copy the code
Next, we copy the contents of the public key and log on to Github
In the upper right corner, select Settings -> SSH and GPG Keys and click New SSH Key.
Run the SSH -t [email protected] command to check whether the SSH configuration is successful.
Git Basic Operations
- Initialize the new warehouse
git init
Copy the code
- Viewing file Status
git status
Copy the code
- File tracking
git add xxx // Trace a file
git add . // Batch tracking
Copy the code
If the file was added successfully, we can check again with git status
- The file is committed to the local repository
git commit // Submit the file to the local repository
git commit -m 'xxx' // XXX is the information you submit this time
git commit -am 'xxx' // All tracked files are temporarily stored and submitted together
Copy the code
- Push remote Warehouse
git push origin xxx
// You can specify a default source with -u, so that you don't need to add origin to push in the future
git push -u origin xxx
// In the future
git push
Copy the code
- Pull the remote warehouse
git pull origin xxx
Git pull = git pull = git pull = git pull = git pull = git pull
git branch --set-upstream branch-name origin/branch-name
Copy the code
- diff
git diff
Copy the code
- Viewing the Commit History
git log // List all updates by the time they were submitted, with the most recent at the top
git log --oneline // View a brief history
git reflog // It is used to record each command. It is often used to assist in version switching
Copy the code
A normal code commit process
git add .
git commit -m 'xxx'
git pull
git push
Copy the code
Git Version Switch
Sometimes business scenarios, or changes in requirements, etc., require us to switch back to a previous version.
To switch versions, we need to know which version we are in:
git log --oneline
Copy the code
Git reset –hard id command to switch to the current version. The ID can be:
-head ^: last version -head ^^: last version -head ~10: last 10 versionsCopy the code
When you switch back to the previous version, you can no longer see the latest version in the Git log, so you can use git reflog, which is arranged according to all previous commit paths.
Git Branch Management
Dev or any other development branch is separated from the master branch and used for development, so that if there is a problem in development, the main branch will not be affected.
Create a new branch with git Branch XXX.
Use Git Checkout XXX to switch to the new branch
Branch, checkout:
git checkout -b xxx // You can quickly create and switch to a new branch
git branch -d xxx // When the branch is merged into the main branch, the branch can be deleted by -d
git branch -D xxx // Delete branches that are not merged
git branch -a // View all branches
Copy the code
Branch merge
Note: When merging branches, you must make sure that you are on the target branch to which you are merging
Use git merge XXX to merge branch XXX into your current branch.
Normal merge branches is very simple, that is ok, but the branch to merge, if in different branches of the modified the same part of the same file, the git is unable to determine which branch of the code, the use that will generate conflicts, although the git merged, but did not submit, we need to resolve the conflict and resubmit.
We can use Git status to check which files are in conflict and then solve them one by one. When we fix the conflicting code according to the correct code, we need to re-git add, git commit, and Git push.
Operate remote warehouse
Clone Remote warehouse
Git Clone URL to clone the remote repository
Such as:
// By default, this will create a blog-mason folder in the path you pulled
git clone https://github.com/MasonEast/blog-mason.git
// If you don't want the folder blog-mason, you can do this: after the URL, add the new name with space
git clone https://github.com/MasonEast/blog-mason.git newName
// If you want to put the project files in the current path, instead of the outside folder, you can use it.
git clone https://github.com/MasonEast/blog-mason.git .
Copy the code
Check the remote repository git Remote
Our clone repository will see a remote repository named Origin through Git Remote, which is the default git identification of the clone’s original repository
Git remote -v or git remote –verbose allows you to see more detailed information, i.e. the corresponding project address. Normally there are two, but if you don’t have push permission you can only see the fetch address.
git remote -v
origin [email protected]:MasonEast/blog-mason.git (fetch)
origin [email protected]:MasonEast/blog-mason.git (push)
Copy the code
Deleting a remote branch
git push origin :xxx
/ / can also
git push origin --delete xxx
Copy the code
Deleting a remote repository
git remote rm xxx
Copy the code
Rename the remote repository
git remote rename oldName newName
Copy the code
About misoperation
Git is mainly used for version control and collaborative development. Misoperations can be undone, but some of them are irreversible, so we must be careful, or some codes may be lost.
Modify the last commit
Scenario: After a submission, we find that there are few files submitted. We need to revoke the submission and resubmit it.
git add xxx // Add less committed files to the staging area
git commit --amend // Append the file that was undercommitted to the last commit. No record will be generated for this commit
Copy the code
Remove files from the local repository
Scenario: After we commit a file to a local repository using Git commit, we remember to add a file we don’t want to commit.
git rm xxx
Copy the code
Removes files from the staging area
Scenario: Sometimes we are used to git add., but there are files that we should not commit, so we need to remove them from the staging area.
git reset HEAD xxx // Remove file XXX from the staging area
Copy the code
The latter
The above is just the basic operation that may be used in daily work. Here is a little arrangement. There are many advanced git learning commands that have not been mentioned, such as Git Stash, Git Rebase, etc., mainly because I haven’t fully understood it, it is not good to mention here.