区块链:IPFS:下一代网络Web3.0的最佳“候选对象”-ODAILY_WEB

在过去的几十年里,我们大部分人都从互联网给我们生活带来的巨大变化中获益良多。我们现在已经习惯了不断获取信息,通过社交媒体建立虚拟社区,以及电商网站提供的便利。而其实所有的这些都是通过超文本传输协议实现的,HTTP协议于1989年推出,旨在促进欧洲核子研究委员会研究人员之间的信息共享。

但是自Web1.0早期发展阶段以来,线上内容已经有了很大的发展。那时,网页大多是静态的,很少涉及用户生成的内容或交互信息。随着互联网迈向Web2.0的发展,这种格局开始转向注重互操作性和参与性文化,这种文化可以从维基百科、博客、视频和图像共享网站、社交媒体平台上的大量的用户生成内容中体现,以及满足流媒体服务需求。但是,这些带宽密集型超媒体的出现,以及物联网可能带来的大量数据涌入,逐渐给互联网带来压力,促使一些人想要寻求替代品。

IPFS:“更快、更安全、更开放的网络”

构建下一代网络Web3.o的一个有希望的候选对象是星际文件系统,这是一个相对较新的超媒体协议和去中心化数据存储系统,它使用了点对点网络架构。

IPFS这个科幻的名称是对美国计算机科学家J.C.R.Licklider在20世纪60年代关于“星系计算机网络”的思考的肯定。IPFS最早是2014年由美国计算机科学家、协议实验室创始人胡安·贝内特开发的,旨在解决HTTP存在的一些缺点。贝内特的目标是创造一些最终可能成为“互联网的新型子系统”的东西,同时也考虑到诸如支撑区块链的分布式账本技术等新的发展。

协议实验室的工程经理MikealRogers解释称,“IPFS是一个去中心化的数据网络,世界上的任何人都可以在网络中提供数据,也可以安全地从他们或任何其他人那里接收到数据”。IPFS过去是,现在仍然是作为Web3.0的数据传输协议来开发的。由于该协议是完全去中心化的,所有的数据都是通过哈希来处理的,因此它非常适合需要处理大量数据的区块链应用程序,而这些数据本身无法嵌入链中。”

以IPFS为基础的去中心化模型与运行HTTP的客户-服务器模型形成了鲜明的对比。HTTP最初设计用于在web浏览器和web服务器之间传输信息,它是基于位置寻址,允许用户访问存储在中心化服务器上的数据。虽然这简化了数据的管理和分发,但效率不高。这是因为当你点击一个网站时,你的web浏览器必须直接连接到托管该网站的服务器。对于内存较大的音频和视频文件,它可能会占用大量带宽,甚至相当昂贵,特别是当源服务器位于很远的地方的情况下。浏览或下载热门内容也会导致网络拥塞。HTTP还存在潜在的隐私和安全问题:控制服务器的任何人都可以访问或更改数据,或者由于黑客的分布式拒绝服务攻击导致网络无法访问。

IPFS微信指数日环比下降14.46%:金色财经报道,微信指数显示,7月29日,区块链微信指数为1776780,日环比上升0.89%;比特币微信指数为933003,日环比下降33.20%;以太坊微信指数为112651,日环比下降28.65%;IPFS微信指数为348653,日环比下降14.46%。[2020/7/30]

相比之下,IPFS是基于内容寻址,这样就可以验证内容并且与远程服务器分离,并将内容存储在更靠近用户的位置。它可以通过使用内容标识符或“标签”来实现这一点,这些标签在IPFS中用于指向材料。CID是基于内容的加密散列而生成的。

雄岸基金与四块科技共同布局全球IPFS分布式存储生态:2018年6月14日下午,雄岸基金创始合伙人姚勇杰先生和四块科技创始人冯国东先生,在雄岸基金杭州总部成功签约合作,共同布局全球互联网IPFS分布式存储生态。[2018/6/15]

Rogers表示:“当你把数据放入IPFS时,它可以通过哈希地址或CID来获得,世界上的任何人都可以把这个地址输入他们的电脑,然后检索数据。就像世界上任何人都可以将URL链接放入浏览器并进行检索一样,任何拥有CID的人都可以检索IPFS网络中可用的数据。”

内容中的任何差异都会导致不同的CID,而添加到不同IPFS节点的相同内容仍将产生相同的CID,这意味着用户可以轻松地验证数据的完整性。除了提供去中心化的内容存储和验证之外,IPFS还可以用于构建和托管去中心化应用(DApps),这是一种开源的计算机应用,其后端代码是运行在点对点网络上。

Rogers补充道,“有了CID,你要找的数据散列就在地址中,所以你可以从任何地方获取数据,因为你可以通过比较散列来验证数据的正确性,它可以让你拥有一个去中心化,去信任的网络,因为您可以从任何地方或任何人那里检索数据,并且通过加密方式验证数据是否正确。”

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

大币网

[0:0ms0-5:598ms