IPFS系列01-IPFS 前世今生

元宇宙的兴起让 Web 概念又火了一波,作为 Web3 存储基石的明星项目 IPFS ,以及去中心化存储网络 Filecoin 又重新回到大众的视野。本专栏主要记录了笔者从 2018年至今研究 IPFS 的笔记,让对 IPFS,Filecoin,Lotus 从概,到源码有一个成体系的认知,第一篇文章我们首先来了解 IPFS 的前世今生。

1. IPFS 它是什么?

关于 IPFS 的理解,网上众说纷纭,很多人说它是区块链项目,也有人说它是分布式文件系统,还有人说它是矿机...

这里我们先抛开那些概念,首先我们看看IPFS官网(https://ipfs.io)对它的描述:

A peer-to-peer hypermedia protocol, to make the web faster, safer, and more open.

翻译过来是:一个点对点的超媒体协议,使得互联网更加快速,更加安全,更加开放.

提取一下句子的主谓宾, 你就能得到清晰,简明的定义: IPFS 是一个协议

这样理解起来很简单,但是有点抽象,根据信息论,要想消除一个事物的不确定性,减少信息熵,唯一的目的就是引入更多的信息,所以我们把定语还原:

IPFS 是一个 点对点超媒体 协议。

2. IPFS 它要干什么?

这个我们还是从 IPFS 官网寻找答案:

IPFS aims to replace HTTP and build a better web for all of us.

这样看来 IPFS 协议诞生的目的是为了干掉 HTTP 协议,HTTP 协议出现到今天已经过去了半个多世纪,确实遇到一些瓶颈,并且
很少有一些设计能够增强整个 HTTP 网络或者为它带来新的功能。IPFS 的目标是就是取代 HTTP,重新建立一个完全去中心化,没有防火墙,没有政府监管,没有监控的
新的互联网世界。

3. IPFS VS HTTP

首先Http 是一种客户端-服务器的中心化访问模式,IPFS 是完全去中心化. http 是基于地址(主机ip)定位资源的,IPFS 是通过内容地址(Hash)定位资源
(具体的资源访问方式我们会在后面文章专门阐述)。

3.1 存储和访问

HTTP 是整文件存储,而 IPFS 是将文件切分成多个 chunk(文件碎片) 分散存储到多个节点,然后通过文件校验机制获取完整文件,这样使得文件的存储和访问更加高效
尤其是对于大文件来说,IPFS 的优势更加明显. 再者,在HTTP的文件系统中,存在大量的重复文件,而 IPFS 通过将文件切片之后,同一个切片只会保存一份,
大大提高文件碎片的重用性,节省存储空间。

3.2 传输

IPFS 传输高效,节约带宽资源,IPFS地址不是指的位置,而是直接指向资源,并确保这些数据都是来自最近的资源。
IPFS也会自动选择离你距离最近,带宽最流畅,存储速度最快,最可靠的节点来帮你存储数据,虽然你依然可以使用 HTTP + CDN 来使得服务器更靠近你,
但即使这样,可能最近的服务器还是离你有几百公里远,而且 CDN 的使用成本过高,只有少数大的互联网公司才用的起。

3.3 可靠性和持久性

HTTP 的可靠性就不用说了,你每天打开的那些 404 页面已经足够说明问题了。至于持久性,研究表明,现在一个网页的平均寿命是100天。人们每天都在删除历史数据。
IPFS 将会采用和Git类似的机制来记录文件的修改,保留多个数据版本,而不是每次修改后拷贝复制整个文件,并使用梅克尔树(Merkle DAG)来验证文件的完整性。
随着IPFS的缓存系统到位,默认情况下,很多可定期查看的内容完全可以脱机使用。

3.4 抵御DDoS攻击

HTTP 服务几乎是没有办法抵御攻击的,必须依赖硬件防火墙这些网络设备。因此一旦有人发起了 DDoS 攻击,将会大大降低 HTTP 服务的可用性。而 IPFS 是天然抗
DDoS 攻击的,因为发动 DDoS 攻击的前提是你必须先知道文件存储在那台服务器上,而 IPFS 的文件是分散存储到很多个节点上,这样就使得你无法定位你要攻击的
节点。

下面用个简单的表格来展示 IPFS 和 HTTP 的现状对比

VS HTTP IPFS
存储 存在大量的冗余数据 切分成 chunk 可去重,节省空间
带宽 需要大量的带宽资源 需要的带宽资源少,节省带宽
可靠性 容易丢失 可以保留多个数据版本
开放程度 中心化,掌握在少数机构手中(IBM,亚马逊,阿里云等服务器运营商) 完全去中心化,更开放

4. IPFS 整体架构

作为一个分布式的文件系统,IPFS 提供了一个支持部署和写入的平台,同时能够支持大文件的分发和版本管理;为了达到上述的目的,
IPFS 协议被分成如下的几个子协议:(本次只是对各个协议做个简单的介绍,后期我专门对每个子协议做详细的介绍)

Identities(身份认证) | 在 IPFS 网络中,所有的节点都通过唯一的 NodeId 进行标识,为了对抗女巫攻击(恶意创建多个节点),IPFS 内置了一个轻量级的 POW算法来生成节点 ID.
NetWork(网络) | IPFS 可以使用任意的网络进行通信,它并没有假设自己一定运行在 IP 协议上,而是通过 multiaddr 的格式来表示目标地址和使用的协议,以此来兼容和扩展未来可能出现的其他网络协议。
Route(路由) | IPFS 路由使用的是 DHT(分布式Hash表), 同时采用了 IPNS 来解析路由记录。
Exchange(数据交换)| 在 IPFS 中,数据的分发和交换使用 BitSwap 协议,BitSwap 负责两件事情:向其他节点请求需要的 Block 以及为其他节点提供 Block, 对应使用的是, 这里借鉴的是 BitTorrent 技术,
MerkleDAG(文件存储)| 这时 IPFS 文件系统的核心,是 IPFS 团队在 Git 文件系统的基础上进行了改进后的文件存储数据结构
Naming(命名) | IPFS 使用了自我认证认文件系统-SFS,并在其基础上发明了IPNS,解决了 MerkleDAG 易变的命名的问题。
Application(应用)|用户可以在 IPFS 基础上构建应用

5. 总结

本文对 IPFS 做了一整体的介绍,旨在让大家对 IPFS 有个整体的印象,它是一个点对点的超媒体协议,以及大概讲述了它是如何解决 HTTP 当前的一些痛点的,
后面会写系列文章对 IPFS 的各个子协议做专门的介绍.

本文首发于 小一辈无产阶级码农

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容

  • 我断断续续看完了《镇魂》、《默读》、《山河表里》、《大哥》,现在刚刚看了几页《有匪》。 不知道为啥,我感觉《有匪》...
    海边的蓝兔子阅读 476评论 0 5
  • 《夏天》 蝴蝶 蝴蝶 快醒来 我的嘴角开了花 青蛙 青蛙 快过来 我的池塘有荷花 壁虎 壁虎 掉了尾巴往上爬 墙上...
    羽蒙剪烛阅读 394评论 3 5
  • 上个月底搬了新家,因为之前的办公电脑在房间,而老婆也在房间带小孩子,所以经常会使唤我帮忙带小孩子。经常在业余时间工...
    周志松实战日记阅读 327评论 0 0