The InterPlanetary File System (IPFS) represents a transformative approach to how we perceive and interact with data on the internet. To truly appreciate the innovation behind IPFS, we need to first understand the limitations of our current web structure.

Source: 101blockchain
Traditionally, when we access a website or an online document, we’re essentially asking a specific server (or a group of servers) to show us that content. This is called location-based addressing. While this system has served us well for many years, it has inherent flaws:

Source: https://symphony.is/
IPFS introduces a novel way of accessing data: content-based addressing. Instead of asking “where” a piece of data is stored, IPFS focuses on “what” that data is. In IPFS, every file and each of its blocks are given a unique fingerprint known as a Content Identifier (CID). This CID doesn’t just identify the content; it’s derived from the content’s details, ensuring authenticity.

Behind the scenes, IPFS uses a structure known as the Merkle Directed Acyclic Graph (DAG). In simple terms, it’s a way of organizing and linking data blocks. Each block contains data and is linked to other blocks through cryptographic hashes. These links form a web-like structure, ensuring data integrity and efficient retrieval. If you’ve ever seen a family tree, the Merkle DAG is somewhat similar, but instead of relatives, it connects blocks of data.
IPFS’s unique approach to data storage and retrieval hinges on its peer-to-peer (P2P) structure. This architecture is a departure from traditional internet models, and it’s instrumental in addressing many of the inherent flaws of the centralized web.
Unlike traditional networks where there’s a clear distinction between servers (providers of content) and clients (consumers of content), in a P2P network, every participant can be both. This means:

IPFS is not the first P2P network, but it brings innovations that make it particularly suited for the decentralized web:
While IPFS’s decentralized nature offers unparalleled advantages, it also poses unique challenges, especially concerning data persistence.
To ensure efficient resource use, IPFS nodes might occasionally purge infrequently accessed data. This garbage collection process ensures that nodes don’t become overwhelmed with dormant data. However, essential data must be protected from such purges.
Pinning is the IPFS solution to the challenge posed by garbage collection. By pinning a piece of data, users mark it as vital. This ensures that, regardless of garbage collection cycles, the pinned data remains stored and accessible on the network.