Use Git Prune command to clean up Git repository
In this article, we will discuss git prune
the command and its uses. We know that Git is very careful with our data.
When we delete data like commits, Git doesn't easily lose them. This can lead to stale data piling up in our machines.
This is git prune
where the command comes into play.
We can git prune
call the command a housekeeping utility in Git that is used to clean up orphaned or unreachable Git objects. When we talk about unreachable objects, they are objects that are not reachable from the current refs in our repository.
A good example is when we git reset <Commit ID>
roll back to a previous commit using the command. Git stores the deleted commit as a dangling object.
We use git prune
the command to eliminate such data.
Use git prune
the command
git prune
The command has several useful options, which are listed below.
$ git prune --dry-run
We run the above command to get the output of the command. It does not execute prune
.
$ git prune --verbose
The above command will show us all actions and related objects.
$ git prune --progress
We use the command above to check git prune
the progress of .
$ git prune --expire <time>
We use the above command to delete <time>
objects older than a specified time ( ).
To better understand this concept, let's look at a practical example. Let's run git log
the command to check the commit history in our local repository.
$ git log --oneline
Let's git reset
roll back a commit using the command so that our HEAD
is at 第六次更新
.
$ git reset --hard 27bd68b
HEAD is now at 27bd68b Sixth Update
Let's try to find the deleted commit.
$ git fsck --lost-found
The deleted commit is first; we can confirm this with the first seven characters.
Before running git prune
the command, we must run a reflog
which will now
expire entries older than .
$ git reflog expire --expire=now --expire-unreachable=now --all
It would be best to dry run
run this command and see what changes occur.
$ git prune --dry-run
We can now run prune
the command.
$ git prune --verbose --progress --expire=now
Let's check if the dangling commit still exists in our repository.
$ git fsck --lost-found
git prune
The difference between , git fetch --prune
andgit remote prune
git fetch --prune
The and git remote prune
commands have similar functionality. We use them to delete references to deleted branches in the remote repository.
It comes in handy when working as a team and you want to get rid of remote branches that were deleted after being merged into the master branch.
git fetch --prune
A command is a combination of:
$ git fetch --all && git remote prune
It will prune
fetch from our remote repository before starting As mentioned before, the basic git prune
command will delete the local objects.
For reprinting, please send an email to 1244347461@qq.com for approval. After obtaining the author's consent, kindly include the source as a link.
Related Articles
Git diff shows diff details of uncommitted changes
Publish Date:2025/03/31 Views:105 Category:Git
-
This article outlines how we can get diff details of uncommitted work in Git. We use the git diff command to show the differences between various Git references, such as commits, the index, and the working tree. We can use this command to d
Staging area in Git
Publish Date:2025/03/31 Views:152 Category:Git
-
In this article, we will learn about the staging area in Git . Git is a version control system that maintains a history of changes made to a project directory. Git uses commits to track changes. Git has three internal management systems, on
Add all files in a folder to commit in Git
Publish Date:2025/03/31 Views:159 Category:Git
-
This article will discuss the necessary steps to add all of your files into one folder for submission. If you have a folder with a dozen files, adding the files one by one can be tedious. Fortunately, Git allows us to add all the contents o
Meaning of Fetch_Head in Git
Publish Date:2025/03/31 Views:64 Category:Git
-
This article defines Fetch_HEAD in Git . This reference is an integral part of the git pull command and is important when merging changes from a remote repository into a local repository or branch. If you're not sure what Fetch_Head means,
Get all branches in Git
Publish Date:2025/03/31 Views:63 Category:Git
-
This article discusses how to fetch all branches from a remote repository. The git fetch command is a useful utility when you want to download changes from a remote repository without having to update your local branches. Sometimes, you may
Clone a Git repository with a specific revision
Publish Date:2025/03/31 Views:83 Category:Git
-
This article discussed various methods that we can use to clone a Git repository with a specific revision or changeset. This comes in handy when you have a repository with large files and you only need a specific version of the code. Instea
Squash commits pushed in Git
Publish Date:2025/03/31 Views:87 Category:Git
-
This article outlines the process of squashing commits that we have pushed to a remote repository. We squash the commits into one to reduce clutter in the repository. To squash the commits, we run git rebase in interactive mode . Squash com
Git squash all commits
Publish Date:2025/03/31 Views:65 Category:Git
-
In every developer’s life, the word squash is often used while working with the Git distributed control system . This feature in Git is a handy option that developers often use to achieve a neat workflow in their development team. In this
Close the Git commit editor on Windows
Publish Date:2025/03/31 Views:62 Category:Git
-
In this article, we will discuss how to exit the Git commit editor. This can be a little tricky, especially if you are new to Git bash . Let's see how to exit the editor on Windows. Close the Git commit editor on Windows We will look at a t