Git rollback of remote version
1. The beginning of the story
The code under the remote master branch was accidentally submitted with a lot of junk code or the project was deleted. I wanted to roll back to a previous version and delete the commit log. what to do? The scenario is as shown in the picture:
The scenario is very simple. My boss uploaded a file and I deleted it. There is a way to push the file again, but you don’t want him to see the comment in the picture (ps: this way I won’t be fired). The code to implement the above scenario is as follows:
vim A.txt
git add .
git commit -a -m "add A.txt"
git push
rm A.txt
git commit -a -m "I deleted the boss's stuff"
git push
————–Separating line————–
What should a confused newbie do? what to do? what to do?
The submission pushed to the remote cannot be modified by default, but it must be modified:
git push -f
2. Solution
2.1 Workspace, staging area, local repository & remote Version library
No pic say 78. . .
》》Workspace: It is the directory where we operate
》》Staging area: a snapshot of the operating directory
》》Local repository: the essence of Git, everyone is the central warehouse. That is to say, the benefits of Git distribution are naturally compared to the centralized version like SVN
》》Remote version library: a central warehouse like Github can achieve sharing.
Commonly used operations are also shown in the picture, which is self-evident.
2.2 Practical solution
Talk is cheap, Show me the code or money~ The code is as follows:
git log
git reset --soft ${commit-id}
git stash
git push -f
The detailed explanation is as follows:
Line 1: git log View the commit history, and then find the version to be rolled back. The history is as follows,
commit 84686b426c3a8a3d569ae56b6788278c10b27e5b
Author: JeffLi1993
Date: Fri Apr 8 19:1 1:32 2016 +0800
I deleted my boss’s stuff
commit 72bd6304c3c6e1cb7034114db1dd1b8376a6283a
Author: JeffLi1993
Date: Fri Apr 8 19:05:23 2016 +0800
add A.txt
The version we want to roll back to That is: 72bd6304c3c6e1cb7034114db1dd1b8376a6283a
Line 2: git reset –soft 72bd6304c3c6e1cb7034114db1dd1b8376a6283a
Undo the previous version Modify and return to the temporary storage area (I don’t know how to look at beautiful pictures~). The difference between soft and hard parameters is that hard modification records are lost, while soft will retain modification records.
Line 3: Temporarily saved for safety reasons.
Line 4: git push -f
Push the local master to the remote repository, -f forces overwriting.
3. Summary
git reset rolls back to a certain version
git push -f forces push overwrite

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

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics











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

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

Git Commit is a command that records file changes to a Git repository to save a snapshot of the current state of the project. How to use it is as follows: Add changes to the temporary storage area Write a concise and informative submission message to save and exit the submission message to complete the submission optionally: Add a signature for the submission Use git log to view the submission content

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.

When developing an e-commerce website, I encountered a difficult problem: How to achieve efficient search functions in large amounts of product data? Traditional database searches are inefficient and have poor user experience. After some research, I discovered the search engine Typesense and solved this problem through its official PHP client typesense/typesense-php, which greatly improved the search performance.

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

How to update local Git code? Use git fetch to pull the latest changes from the remote repository. Merge remote changes to the local branch using git merge origin/<remote branch name>. Resolve conflicts arising from mergers. Use git commit -m "Merge branch <Remote branch name>" to submit merge changes and apply updates.

To delete a Git repository, follow these steps: Confirm the repository you want to delete. Local deletion of repository: Use the rm -rf command to delete its folder. Remotely delete a warehouse: Navigate to the warehouse settings, find the "Delete Warehouse" option, and confirm the operation.
