The popularity of code hosting platforms such as GitHub and GitLab has made Git a much-discussed version control tool, and more and more people have understood how Git works. However, understanding the appearance of Git is only to use Git. To truly understand Git, you also need to understand the underlying processing flow of Git.
Overview of the underlying structure of Git
Git is a distributed version control system, corresponding to a centralized version control system (such as SVN). Because of the distributed nature of Git, each Git repositories are complete repositories.
The working directory of Git contains two parts: Git warehouse object and working tree. The status of Git warehouse object and working tree can be analogized to the relationship between aliases, hard links and soft links respectively.
Git’s underlying file storage method
Git’s underlying file storage technology is mainly divided into two aspects:
- Object storage
- Compressible files Usage of format
Object storage
Git saves all code changes as individual objects, among which the key objects are blob, tree and commit. Among them, blob is a snapshot of code content, tree is a snapshot of a set of files and directories, and commit is a snapshot of code changes.
Careful readers will find that these objects are somewhat similar to the inode mechanism in Linux systems. An inode file node can represent a file or directory, and an inode file node contains information such as the disk block number. In Git, blob is the snapshot object of the file content in the inode file node, tree is the snapshot object of the inode directory, and commit is the version snapshot composed of multiple inode file nodes.
In Git, objects are usually represented as SHA1 hashes. The SHA1 hash value is a hexadecimal string of 40 characters. Git uses SHA1 hashes to assign a unique identifier to each version, each file and directory, and each commit.
Use of compressible file format
The bottom layer of Git uses a technology that adds a part of metadata to the file to handle code changes. Metadata is often some intermediate state, such as change information between two commits. This information can be compressed into small files and decompressed when needed.
The default file format used by Git is packfile format. Packfile is a highly compressed Git object storage format that can archive multiple objects into a single file for transfer when Git performs cross-network operations.
Git's underlying core processing process
In the previous content, we have a detailed understanding of Git objects and underlying file storage technology. Next, we will enter the underlying core processing process of Git.
Git initialization process
- Create directory.git/
- Create subdirectory.git/objects/
- Create subdirectory.git/ refs/
- Create an empty HEAD file
- Create an empty index file
Git’s basic file command
Here we first introduce Git A brief introduction to the various basic file commands:
- hash-object command: used to convert files into Git objects.
- cat-file command: used to display the contents of Git objects.
- ls-tree command: used to display the contents of a certain Git tree.
- update-index command: used to add files or directories to Git index.
- write-tree command: used to convert Git index into a Git tree object.
Git's submission process
Git's submission process still consists of three fields: Blob, Tree, and Commit.
- Blob: Used to represent the metadata of each file in the code, including file name, file type, and of course SHA1 hash value, etc.
- Tree: Based on the Blob in the previous step, assemble the corresponding files and directories to form a snapshot tree and save it in a Git node.
- Commit: Assemble the above two objects plus the submitted user information to form a version snapshot.
In the above steps, there are some things that need to be paid attention to. For example, when performing Blob conversion, you need to add the -g parameter.
Git's branch process
In Git, branches are independent pointers pointing to the last submitted object. There are two types of branches: local branches and remote branches.
After the local branch is created, adding a new submission will automatically move HEAD to point to the latest submission. During this period, the checkout command is used to switch between different branches. Remote branches refer to a way of collaborating code between different local libraries.
Summary
This article elaborates on the underlying processing process of Git from two aspects: Git's underlying file storage method and Git's underlying core processing process. Through the explanation of Git objects and underlying file storage technology, we understand the underlying architecture of Git. This article also introduces the underlying core processing process of Git, including Git's initialization process, Git's basic file commands, Git's submission process, and Git's branch process. Through an in-depth understanding of the underlying processing flow of Git, we can better understand the operating mechanism of Git and use Git for version control more efficiently.
The above is the detailed content of The underlying processing flow of 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

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

Dreamweaver CS6
Visual web development tools

WebStorm Mac version
Useful JavaScript development tools

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

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),
