IPFS

IPFS是Interplanetary File System的缩写,直译过来就是“星际文件系统”,是一个点对点的超媒体协议(“A peer-to-peer hypermedia protocol")。

我们可以看出,IPFS的本质是一份“协议”,通过“点对点”的方式进行网络的组织,在这样一个去中心化的存储网络中,每个节点都可以提供存储空间,供网络中的其他节点进行存储。同时也提供传输,依据规则向网络中需要读取该文件的节点发送本地存储的文件。它是一个面向全球的、点对点的分布式文件系统,试图将所有相同文件系统的计算设备连接在一起。

IPFS宣布了一个未来Web发展计划,它用基于内容的地址替代基于域名的地址。也就是说用户寻找的不是某个地址而是存储在某个地方的内容,不需要验证发送者的身份,而只需要验证内容的哈希,通过这样可以让网页的速度更快、更安全、更健康、更持久。IPFS的成功应用将会取代HTTP,成为下一点互联网传输的基石。

总结:IPFS是一个面向全球的、点对点的分布式版本文件系统,目标是补充甚至取代目前统治互联网的超文本传输协议(HTTP),将所有具有相同文件系统的计算设备连接在一起,希望构建速度更快、更安全、更自由的互联网时代。

二、HTTP存在的问题

高度集中化

Web的本意是去中心化,但却变得越来越中心化,今天我们使用的网络服务绝大部分是少数几个网站的服务,如Google、Amazon、腾讯、阿里等。我们每一次访问网络服务都需要连接到中央服务器,中央服务器再将这些数据返回给我们。数据的传输速度取决于网络带宽,如果很多人同时访问中央服务器,会导致延迟甚至无法访问。假如某天这些公司的服务器遭受大量的网络攻击,或是自然灾害导致的服务器瘫痪,我们全球的网民就无法使用他们提供的服务了。可见HTTP变成了一个高度集中的、脆弱的、过度依赖于骨干网络的协议。

将Web进行去中心化,可以大大降低少数组织的延展性,提高所有节点的独立性和自由度,同时也降低了由于服务器中断造成的数据丢失的风险。

维护成本高

中心化的服务器,因为要保障数据服务的稳定性和安全性,所以维护成本非常高。在中心化服务运维中,有一个KPI指数叫SLA,稳定性没有达到99.9%的话,基本不合格。SLA需要消耗特别大的成本,大公司需要雇佣一批运维专家或专业人士,去保障系统的稳定性。

不然12306也不会宣传花费了1个亿去建一个购票网站了,即使这样,在高峰时刻也还是不得不拔网线。

过度依赖于Internet主干网

当内容过度集中化之后,数据中心就会高度依赖于Internet主干网络。这样除了有利于政府对内容进行封锁和审查,事实上会存在很多问题。因为主干网络有可能会被损坏,出现路由表失控、或者遭受攻击等问题。

三、IPFS的应用优势

IPFS架构

IPFS有八层协议栈,从上至下分为:身份、网络、路由、交换、对象、文件、命名、应用,每个协议栈各司其职,又相互搭配。

技术上不太懂,总的来说,IPFS具有两大核心优势:

1、大大提高系统效率;

2、大大降低系统成本。

基于内容寻址

目前通过HTTP浏览器搜索文件的时候,首先要找到服务器的位置(IP地址),然后使用路径名称在服务器上查找文件。IPFS从根本上改变了用户搜索的方式,通过IPFS,用户搜索的是内容。只有文件所有者可以判断这是否是用户要找的文件,此时,必须保证托管者不会通过移除文件或者关闭服务器对文件做任何更改。

当文件被添加到IPFS节点上,它得到了一个新的名字,这个名字就是一个加密哈希,它是由文件内容被计算出来的。通过加密哈希保证了该哈希只表示该文件的内容,哪怕对文件只做一点点修改,哈希值就会完全不同。当下一步向IPFS网络询问哈希的时候,它通过一个分布式哈希表,可以快速找到拥有该数据的节点,从而检索该数据,并使用哈希验证是否是正确的数据。

IPFS服务的文件可大可小,对于一些大的文件,它会自动将其切割为一些小块,使IPFS节点不仅仅可以像HTTP一样从一台服务器上下载文件,而且可以从数百台服务器上进行同步下载。IPFS网络是一个细粒度的、可靠的、分布式的内容分发网络(CDN)。

小结:IPFS应用基于内容的地址替代基于域名的地址,也就是用户寻找的不是某个地址而是存储在某个地方的内容,不需要验证发送者的身份,而只需要验证内容的哈希,通过这样可以让网页的速度更快、更安全、更健壮、更持久。

四、IPFS的应用意义

一、为内容创作带来自由

Akasha是一个典型的应用,它是基于以太坊和IPFS的社交博客创作平台,用户创作的博客内容通过IPFS网络进行发布,而非中心服务器。同时,用户和以太坊账户进行绑定,用户可以对优质内容进行ETH打赏,内容创作者能以此赚取ETH。没有太多监管的限制,也没有中间商抽成,内容收益直接归创业者所有。

二、降低存储和宽带成本

用户上传的文件如视频文件,经过IPFS协议进行存储,具有唯一标识。相较于传统视频网站,它降低了同样资源的冗余程度,同时大大节约了海量用户在播放视频时所产生的带宽成本。

三、与区块链完美结合

区块链的本质是分布式账本,瓶颈之一就是账本的存储能力。目前大部分公链的最大问题是没法存储大量的超媒体数据在自己的链上,需要IPFS这样的技术提供底层的数据存储服务。

典型的应用就是EOS,其引以为傲的是可以支持百万级的TPS并发量,其中除了DPOS共识机制的功劳外,还归功于底层存储采取IPFS技术来解决大型数据的传输效率。

四、为传统应用提供分布式缓存方案。

IPFS将中心服务提供的数据通过算法转化成一维字符串,并将与之相关联的具有检索价值的数据存入IPFS网络,并由IPFS网络标识唯一性,然后分布在各个邻近节点上。

当检索请求到来时,系统先通过字符串近似度范围比较,缩小检索范围,加快检索效率。通过临近节点拿到超媒体数据,达到类似分布式缓存的效果,大大提高了传统应用的检索效率。

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

推荐阅读更多精彩内容