IPFS是什么

子凡 问答 2020-09-09 03:17:24 阅读(...)

星际文件系统(IPFS)是一个旨在创建持久且分布式存储和共享文件的网络传输协议。它是一种内容可寻址的对等超媒体分发协议。在IPFS网络中的节点将构成一个分布式文件系统。

星际文件系统(InterPlanetary File System,缩写 IPFS)是一个旨在创建持久且分布式存储和共享文件网络传输协议。它是一种内容可寻址的对等超媒体分发协议。在 IPFS 网络中的节点将构成一个分布式文件系统。它是一个开放源代码项目,自 2014 年开始由 Protocol Labs 在开源社区的帮助下发展。其最初由 Juan Benet 设计。

IPFS 星际文件系统 InterPlanetary File System

在 2014 年,IPFS 协议利用比特币区块链协议和网络基础设施的优势来存储不可更改的数据,移除网络上的重复文件,以及获取存储节点的地址信息——用以搜索网络中的文件。

目前的实现采用 Go 和 JavaScript,并有 Python 的实现正在发展。Go 实现被认为是开发正式规范时的“参考实现”。

描述

IPFS 是一个对等的分布式文件系统,它尝试为所有计算设备连接同一个文件系统。在某些方面,IPFS 类似于万维网,但它也可以被视作一个独立的 BitTorrent 群、在同一个 Git 仓库中交换对象。换种说法,IPFS 提供了一个高吞吐量、按内容寻址的块存储模型,及与内容相关超链接。这形成了一个广义的 Merkle 有向无环图(DAG)。IPFS 结合了分布式散列表、鼓励块交换和一个自我认证的名字空间。IPFS 没有单点故障,并且节点不需要相互信任。分布式内容传递可以节约带宽,和防止 HTTP 方案可能遇到的 DDoS 攻击。

该文件系统可以通过多种方式访问,包括 FUSE 与 HTTP。将本地文件添加到 IPFS 文件系统可使其面向全世界可用。文件表示基于其哈希,因此有利于缓存。文件的分发采用一个基于 BitTorrent 的协议。其他查看内容的用户也有助于将内容提供给网络上的其他人。IPFS 有一个称为 IPNS 的名称服务,它是一个基于 PKI 的全局名字空间,用于构筑信任链,这与其他 NS 兼容,并可以映射 DNS、.onion、.bit 等到 IPNS。

Merkle 数据格式

每个 Merkle 都是一个有向无环图 ,因为每个节点都通过其名称访问。每个 Merkle 分支都是其本地内容的哈希,它们的子节点使用它们的哈希而非完整内容来命名。因此,在创建后将不能编辑节点。这可以防止循环(假设没有哈希碰撞),因为无法将第一个创建的节点链接到最后一个节点从而创建最后一个引用。

对任何 Merkle 来说,要创建一个新的分支或验证现有分支,通常需要在本地内容的某些组合体(例如列表的子哈希和其他字节)上使用一种哈希算法。IPFS 中有多种散列算法可用。

著名的使用案例

  • 于 2017 年 九月至十月间的举办的 2017 年加泰罗尼亚独立公投,由于被 西班牙宪法法院 认定此举动违法,因此其网站被屏蔽。在这之后, 加泰罗尼亚海盗党 将网站整个镜像到 IPFS 上以回避加泰罗尼亚高等法院的屏蔽命令。
  • IPFS 被用于创建维基百科的镜像,让那些住在维基百科被国家法律屏蔽的地方的人民能继续访问到维基百科的内容。那份维基百科是一份被限制改动的复制本且无法被更新。
    文件币 也与 IPFS 有关,是由 Juan Benet 和 协议实验室 合作开发,一套基于 IPFS 的协作存储云。
  • CloudFlare 营运一个分布式的 Web 网关,在无需本地节点的情况下,用以简化,加速并且安全的访问 IPFS 。
  • ISFS 由 Tim Berners Lee 在 2001 年的一篇论文中创造的词汇 是 IPFS 文件分发和存储协议是由多个组件组合起来的协议体系的核心之一。
收藏 0个人收藏
走进科技生活方式

评论交流

泪雪默认头像 请「登录」后参与评论
  1. 加载中..

相关推荐

  • WorkOS

    WorkOS是什么

    WorkOS 是一个允许开发人员向应用程序添加企业功能(如单点登录 (SSO) 和目录同步)的平台。WorkOS 提供了一组构建块,用于向应用程序添加企业功能,例如 OAuth(允许使用包括 Google 和 Microsoft 在内的第三方提供商进行登录)。
  • Encrypted folder 加密文件夹

    如何给文件夹设置密码

    文件夹设密码可以打开“Windows 资源管理器”,请单击“开始→程序→附件”,然后单击“Windows 资源管理器”,右键点要加密的文件或文件夹,然后单击“属性”,在“常规”选项卡,点击“高级”,选中“加密内容以便保护数据”复选框即可。
  • 植入式支付芯片 Implantable payment chip

    植入式支付芯片是未来方向,还是赛博朋克的白日梦?

    目前流通中的银行卡大约有 170 亿张,每天帮助在全球范围内运送难以想象的大量资金,而客户只需简单的刷卡或点击支付终端即可。然而,对于少数用户而言,使用银行卡或手机支付产品费用的想法听起来已经过时且艰巨。
  • DAppNodeHost

    DAppNodeHost是什么

    DAppNodeHost是首款区块链计算机,可以放在家里的区块链节点服务器,支持多币种同时挖矿的家用矿机,是一款支持IPFS,STORJ等分布式存储的家用无限量的私人云盘,同时他还是区块链开发人员可靠的多节点钱包服务器。
  • DAppNode 操作系统

    DAppNode是什么

    DAppNode是一个操作系统,可以让您以真正的去中心化方式托管dapp程序,消除第三方的依赖、不再受中心化影响。它还增加了一层额外的激励措施,有助于推广区块链生态系统的采用并解决基础设施集中化的问题。
  • SVG

    SVG是什么标签

    SVG是是用来制作矢量图的HTML5标签,用来定义SVG图形的容器。SVG可以绘制框、圆、路径、图形图像。在使用SVG标签的时候,可以将标签添加到HTML body中,在为它添加对应的css样式。