深入理解 IPFS - 分层架构总览

2023-12-26 13:38

本文主要是介绍深入理解 IPFS - 分层架构总览,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我们首先从官方文档中一张比较经典的层级架构图开始,右边是 IPFS 的层级图,左边是对应现实网络中的一些实现形式。

   (一) applications 应用层

这个很好理解,就是基于 IPFS 网络开发的应用。我们可以在 awesome 看到一些应用。生态能不能繁荣,肯定是需要开发者参与。

(二) naming 命名

SFS 中文是自我认证文件系统,熟悉其他区块链项目的同学应该很好理解。比如比特币,我们采用非对称加密算法给节点生成了公钥和私钥。通过公钥生成的地址一旦参与转账行为,就会成为比特币网络中一份子,所有节点都知道这个地址。那么怎么证明这个地址是属于你,这就是一个自证明的过程,通过与公钥配对的私钥就可证明所有权。同样对于 IPFS 来说,也采用同样的方式,每个节点的 ID 都是全局唯一的存在,你可以通过 ID 对应的私钥来证明你是这个节点的主人。

举个应用的例子,你有个静态网站想要上传到 IPFS 上,但是网站是需要一直更新内容的,更新后 hash 值变了,在 IPFS 上访问的链接都会变。解决办法是将节点 ID 指向生成的 hash 上。用户访问节点 ID 即可 。

其实不仅仅是文件系统,身份认证(OpenID, OAuth2)可能也会由于区块链的发展出现新的契机。比如 ArcBlock 在推广的 DID。

(三)merkledag

merkledag 是 IPFS 的核心数据结构。比特币中用 merkle tree(默克尔树)快速校验区块数据完整性,使得轻节点钱包无需下载所有交易数据就能校验交易数据。而 merkledag 是一个有向无环图,对象模型和 Git 相似。这部分以后会详细说明。

(四)exchange 块交换

因为 IPFS 是一个全网文件系统,当你上传一个文件的时候,文件会被分割成 block,然后被传输到最近的节点上(XOR)。这样当你再去获取这个文件的时候,节点间就会相互沟通,每个节点都有一个 wantlist 和 havelist,最终找到所有的 block,重新获取到文件。

(五)routing 路由

其实在说到 exchange 的时候,有同学可能发现已经有点熟悉了,这不就是 BitTorrent 么。说的没错,不管是当年的电驴还是现在的迅雷,BT 网络一直很坚挺的存在着。IPFS 的很多设计都是借鉴于它 。说到 BT 的发展,最开始种子是存储到中央 Tracker 服务器上,这样一旦中央服务器挂了,这个种子也就废了,所以发展出了 DHT (分布式哈希表)。节点加入 DHT 网络,所有的资源都通过 hash 来寻址,无需中央节点介入,通过询问自己已知的节点,最终找到目标节点。

对于 IPFS 来说,内容和地址寻址都是同构hash,这样可以避免转换成本。虽然说 routing 的方式不止 DHT 一种,还有 mdns,DHCP。但是作为一个去中心化的项目来说,DHT 是 IPFS 路由必不可少的一项。

(六)network 网络

IPFS 没有创造新的协议来做节点间通信,而是尽可能的兼容现存的所有协议,包括 tcp, http, quic 等等。兼容是通过一个 self-describing 的方式,如 /ip4/7.7.7.7/tcp/6543, 这种风格我们在 IPFS 其他 repos 中也都能看到身影,如 MultiHash, MultiAddress。不得不说,这种 self-describing 的形式在之后的协议升级上会有很大的好处。同样,面对各种网络环境,NAT 穿透也是必备的,IPFS 基于 ICE 框架,支持 TURN 和 STUN。

本文对 IPFS 各层做了简单的介绍,细节我们后续再聊。

这篇关于深入理解 IPFS - 分层架构总览的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/539618

相关文章

MySQL 缓存机制与架构解析(最新推荐)

《MySQL缓存机制与架构解析(最新推荐)》本文详细介绍了MySQL的缓存机制和整体架构,包括一级缓存(InnoDBBufferPool)和二级缓存(QueryCache),文章还探讨了SQL... 目录一、mysql缓存机制概述二、MySQL整体架构三、SQL查询执行全流程四、MySQL 8.0为何移除查

深入解析Spring TransactionTemplate 高级用法(示例代码)

《深入解析SpringTransactionTemplate高级用法(示例代码)》TransactionTemplate是Spring框架中一个强大的工具,它允许开发者以编程方式控制事务,通过... 目录1. TransactionTemplate 的核心概念2. 核心接口和类3. TransactionT

深入理解Apache Airflow 调度器(最新推荐)

《深入理解ApacheAirflow调度器(最新推荐)》ApacheAirflow调度器是数据管道管理系统的关键组件,负责编排dag中任务的执行,通过理解调度器的角色和工作方式,正确配置调度器,并... 目录什么是Airflow 调度器?Airflow 调度器工作机制配置Airflow调度器调优及优化建议最

微服务架构之使用RabbitMQ进行异步处理方式

《微服务架构之使用RabbitMQ进行异步处理方式》本文介绍了RabbitMQ的基本概念、异步调用处理逻辑、RabbitMQ的基本使用方法以及在SpringBoot项目中使用RabbitMQ解决高并发... 目录一.什么是RabbitMQ?二.异步调用处理逻辑:三.RabbitMQ的基本使用1.安装2.架构

一文带你理解Python中import机制与importlib的妙用

《一文带你理解Python中import机制与importlib的妙用》在Python编程的世界里,import语句是开发者最常用的工具之一,它就像一把钥匙,打开了通往各种功能和库的大门,下面就跟随小... 目录一、python import机制概述1.1 import语句的基本用法1.2 模块缓存机制1.

深入理解C语言的void*

《深入理解C语言的void*》本文主要介绍了C语言的void*,包括它的任意性、编译器对void*的类型检查以及需要显式类型转换的规则,具有一定的参考价值,感兴趣的可以了解一下... 目录一、void* 的类型任意性二、编译器对 void* 的类型检查三、需要显式类型转换占用的字节四、总结一、void* 的

深入理解Redis大key的危害及解决方案

《深入理解Redis大key的危害及解决方案》本文主要介绍了深入理解Redis大key的危害及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录一、背景二、什么是大key三、大key评价标准四、大key 产生的原因与场景五、大key影响与危

深入理解C++ 空类大小

《深入理解C++空类大小》本文主要介绍了C++空类大小,规定空类大小为1字节,主要是为了保证对象的唯一性和可区分性,满足数组元素地址连续的要求,下面就来了解一下... 目录1. 保证对象的唯一性和可区分性2. 满足数组元素地址连续的要求3. 与C++的对象模型和内存管理机制相适配查看类对象内存在C++中,规

mybatis的整体架构

mybatis的整体架构分为三层: 1.基础支持层 该层包括:数据源模块、事务管理模块、缓存模块、Binding模块、反射模块、类型转换模块、日志模块、资源加载模块、解析器模块 2.核心处理层 该层包括:配置解析、参数映射、SQL解析、SQL执行、结果集映射、插件 3.接口层 该层包括:SqlSession 基础支持层 该层保护mybatis的基础模块,它们为核心处理层提供了良好的支撑。

百度/小米/滴滴/京东,中台架构比较

小米中台建设实践 01 小米的三大中台建设:业务+数据+技术 业务中台--从业务说起 在中台建设中,需要规范化的服务接口、一致整合化的数据、容器化的技术组件以及弹性的基础设施。并结合业务情况,判定是否真的需要中台。 小米参考了业界优秀的案例包括移动中台、数据中台、业务中台、技术中台等,再结合其业务发展历程及业务现状,整理了中台架构的核心方法论,一是企业如何共享服务,二是如何为业务提供便利。