- TechOps Examples
- Posts
- What Is Inside the .git Folder?
What Is Inside the .git Folder?
TechOps Examples
Hey — It's Govardhana MK 👋
Along with a use case deep dive, we identify the remote job opportunities, top news, tools, and articles in the TechOps industry.
👋 Before we begin... a big thank you to today's sponsor SUPERHUMAN AI
Find out why 1M+ professionals read Superhuman AI daily.
In 2 years you will be working for AI
Or an AI will be working for you
Here's how you can future-proof yourself:
Join the Superhuman AI newsletter – read by 1M+ people at top companies
Master AI tools, tutorials, and news in just 3 minutes a day
Become 10X more productive using AI
Join 1,000,000+ pros at companies like Google, Meta, and Amazon that are using AI to get ahead.
IN TODAY'S EDITION
🧠 Use Case
What Is Inside the .git Folder?
🚀 Top News
Stacked Up 2025 The IaC Maturity Report
57% struggle with consistency and tool sprawl
One in five developers dedicate 33% of their time to IaC
60% of professionals say IaC expertise is still a work in progress
More interesting details inside the report…
👀 Remote Jobs
VRChat is hiring a Senior DevSecOps Engineer
Remote Location: Worldwide
JumpCloud is hiring a Senior Platform Software Engineer
Remote Location: India
📚️ Resources
📢 Reddit Threads
🛠️ TOOL OF THE DAY
terraform module releaser - GitHub Action to automate versioning, releases, and documentation for Terraform modules in monorepos.
🧠 USE CASE
What Is Inside the .git Folder?
We rarely look inside the .git directory, but understanding its structure can help in debugging, recovering lost work, and even optimizing Git performance.
This hidden directory keeps track of everything - commits, branches, history, and configurations, allowing Git to function efficiently.
Here I’ve broken it down into a simple and self explanatory form:

Download a high resolution pdf of this diagram here for future reference.
Let’s go beyond just listing files and dive into why they matter.
1. Objects – The Core of Git’s History
Git stores everything - commits, trees (directories), and blobs (files) as objects in .git/objects/
.
These are immutable and referenced by SHA-1 hashes.
If you accidentally delete a branch, Git might still have its commits in
objects/
. Runninggit fsck --lost-found
can help recover them.Git optimizes storage using packfiles (
pack-xxxx.pack
) to compress and store multiple objects efficiently. Large repos rely on this for performance.
2. Refs – The Named Pointers to Your Work
The .git/refs/
folder keeps track of branches, tags, and remote repositories.
refs/heads/main
holds the latest commit hash of themain
branch.refs/tags/v1.0
points to a specific commit for a tagged release.refs/remotes/origin/main
helps Git know what themain
branch looked like on the remote last time you fetched.
Deleting a branch only removes its reference from refs/heads/
, but the commits might still exist in objects/
until garbage collection runs.
3. Logs – Your Hidden Undo Button
The .git/logs/
directory maintains a history of HEAD movements. Every checkout
, commit
, and rebase
updates these logs.
Lost a commit? Run
git reflog
to find the last known SHA and recover it withgit reset --hard <SHA>
.These logs are temporary and will be deleted when Git runs garbage collection (
git gc
).
4. Config – Tuning Git for Performance and Security
The .git/config
file controls repository settings, including remotes, aliases, and hooks.
If your remote origin URL is incorrect, fix it with
git remote set-url origin <new-url>
.Want faster fetch operations? Enable
git config core.sparseCheckout true
to fetch only specific folders.
5. Index and Staging Area – Where Changes Live Before Commit
The .git/index
file is the staging area. When you run git add
, changes go here before being committed.
If a commit is missing expected changes, check if they were staged with
git diff --cached
.Running
git reset
modifies the index without touching working files.
If you’ve never explored .git/
before, try running ls -lah .git
and start experimenting with git cat-file -p
to inspect objects directly.
You might just uncover something that changes the way you use Git forever.
AWS Cloud roadmaps should be simple.
We make them complicated with roles.
Ideally, they should be phases that one needs to go through.
Phase 1: Basic & General
Phase 2: Basic & Specialized
Phase 3: Advanced & General
Phase 4: Advanced & SpecializedHere, I’ve created this… x.com/i/web/status/1…
— Govardhana Miriyala Kannaiah (@govardhana_mk)
3:16 PM • Feb 17, 2025
I run a DevOps and Cloud consulting agency and have helped 17+ businesses, including Stanford, Hearst Corporation, CloudTruth, and more.
When your business needs my services, book a free 1:1 business consultation.
You may even like: