火星链 火星链
Ctrl+D收藏火星链
首页 > 火币APP > 正文

UST:IPFS存储一致性难题?IPFS-Cluster帮你解决

作者:

时间:1900/1/1 0:00:00

引?言

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

在IPFS网络中,文件是拆分后存储在不同节点的,每个节点存储的内容并不相同,当我们使用IPFS私有网络来作为系统的文件系统时就存在存储一致性问题,如单个节点的故障导致存储的文件不可用。

IPFS-Cluster项目很好地解决了私有IPFS网络数据可用性问题,IPFS-Cluster通过给IPFS网络添加一层分布式共识协议,从而保证IPFS集群节点存储内容的一致性。IPFS-Cluster也是分布式的系统,附加在IPFS节点之上,通过维护全局一致Pinset并和IPFS交互来构建一致性存储。

图1?IPFS-Cluster示意图

IPFS-Cluster架构介绍

星际联盟CEO范国连:Filecoin作为IPFS唯一激励层,拥有不可限量未来前景:3月10日,在2021年IPFS分布式存储高峰论坛上,星际联盟CEO范国连发表了以“一条进军矿业的康庄大道”为主题的精彩演讲。

“在学习中成长,在体验中致富”,他向大家分享了挖矿历史以及投资心态,并隆重介绍了星际大学(星际研究院),星际联盟客户各大机房参观计划,以及2021年第二季度游学方案。

他表示,Filecoin作为IPFS唯一激励层,拥有不可限量的未来前景,选择Filecoin这一拥有落地应用的区块链技术3.0代表项目是极具价值的。而星际联盟作为领先的IPFS分布式存储综合服务商,拥有强大的技术优势和丰富的行业资源。无论你是想挖矿,还是提升财富的增值方式,或是成为IPFS产业的专业人士,星际联盟都能助你走上矿业的康庄大道。[2021/3/10 18:33:14]

IPFS-Cluste是由各功能组件构成的,所以首先需要对组件化及各组件功能进行简单介绍;然后介绍使用IPFS-Cluster进行文件Pin操作的工作流程,与IPFSPin文件工作流程进行对比;Consensus组件是IPFS-Cluster能够完成分布式一致性存储的核心,最后会介绍基于“Raft”的强一致性分布式共识组件,和基于“Merkle-CRDT”的最终一致性共识组件。

BBKX平台将于今日20时免质押币60天填满IPFS云算力认购:据BBKX官方消息,平台将于本周四20:00(UTC+8)开启金色算力云IPFS云算力认购,由金色算力云提供前置质押币,60天填充满有效算力,限量100IPFS。请参与者提前做好准备工作。BBKX平台IPFS云算力为与金色算力云联合推出,起购门槛为530USDT/IPFS,可以满足不同用户的投资需求。 BBKX是一家持续分红的综合型交易平台,已获得节点资本与链上基金联合战略投资。[2020/11/12 12:24:08]

图2?IPFS组件结构示意图

▲?组件化设计

IPFS-Cluster基于组件化设计,同节点的各组件之间通过内部RPC进行通信,此方案很容易把各组件部署到不同的机器,是一种极其容易扩展的架构设计。

IPFS-Cluster由以下8个组件组成:

IPFS微信指数日环比上升37.90%:金色财经报道,微信指数显示,7月28日,区块链微信指数为1761057,日环比上升0.38%;比特币微信指数为1396713,日环比下降70.37%;以太坊微信指数为157885,日环比下降5.71%;IPFS微信指数为407579,日环比上升37.90%。[2020/7/29]

Consensus共识组件:?负责在集群节点之间实现一致性,使所有节点的Pinset保持一致,并且管理节点的加入及退出。目前支持两种共识算法“Merkle-CRDT”和“Raft”。

PinTracker组件:PinTracker处于共识组件和IPFS中间层,PinTracker接收并维护Consensus组件发送的Pin操作,通过RPC组件将Pin操作发送到IPFS。

PeerMonitor组件:?负责维护集群节点的状态,PeerMonitor周期性的检查节点存活状态。

State组件:存储Pin操作的数据库,便于对Pin操作进行增、删、查等操作。

RestApi组件:该组件提供了基于HTTP的ClusterPeer功能的访问服务器。

GOKO将于今日15时开启第三期金色算力云IPFS云算力抢购:据悉,GOKO第二期金色算力云IPFS云算力抢购已于昨日22:00超募售罄,应社区用户的要求,今日15:00将开放第3期抢购,限额200T。

GOKO平台IPFS云算力为与金色算力云联合推出,起购门槛为21.5USDT,可以满足不同用户的投资需求。 云算力可用于Filecoin挖矿,在其今年8月底主网上线后,抢购的用户每日都能收到一定数量的FIL。

GOKO交易所是一个社区化治理的加密资产交易平台,公平、公正、安全可信赖,是一个社区友好型的交易所。目前已获得节点资本战略投资。[2020/7/6]

IPFSProxy组件:是一个代理endpoint,可以用来调用IPFS-Cluster连接的IPFS。某些请求比如Pin/Unpin等会被拦截并触发IPFS-Cluster集群操作,从而操作会在集群所有节点执行。未被拦截的请求都直接转发Cluster所连接的IPFSDeamon。

Allocator/Informer组件:Informer组件用于监控系统的硬盘使用情况、Pin操作的数量。Allocator组件用来选择文件Pin到的具体节点,系统可以根据硬盘使用情况来选择文件存储到的节点,把文件存储到特定的节点。

BBKX平台IPFS云算力第三场认购已售罄:据BBKX官方消息,BBKX平台联合金色算力云IPFS云算力第三场抢购100T已售罄,为了满足更多用户参与IPFS挖矿的需求,BBKX平台将于今晚22:00增设一场IPFS云算力抢购活动,额度仍为100T。

BBKX平台IPFS云算力为与金色算力云联合推出,起购门槛为20USDT,可以满足不同用户的投资需求。

BBKX成立于2019年6月,已获得节点资本与链上基金联合投资,现货交易手续费低至0.05%。[2020/7/3]

RPC组件:?系统使用内部RPC在同节点各组件间进行通信,外部RPC在不同节点各组件间进行通信,提高了系统的可扩展性。

▲?Pin处理流程

当使用IPFS-Cluster添加内容时和IPFSadd命令添加内容命令的选项基本相同。但是IPFSadd命令仅将内容添加到本地IPFS,IPFS-Cluster同时添加到多个集群节点连接的IPFS,具体添加到多少个节点依靠ReplicationFactors参数控制。

Pin和Unpin是集群操作的核心,涉及多个内部组件,但有两个主要阶段:

ClusterPin阶段:持久化Pin操作,并通过共识组件广播给其他集群节点。

首先接收到一个Pin请求,请求包括特定参数。

根据参数会选择Pin到哪个节点,ReplicationFactors决定多少副本,磁盘空间决定选择哪个节点来进行存储。

共识组件负责将Pin请求广播到集群其它节点。

IPFSPin阶段:被指定的IPFS负责将文件内容成功Pin到本地。当Cluster-Pinning阶段完成,每个节点会被通知有个新的Pin工作,如果节点在配置列表中,会调用IPFS来进行Pin操作。

PinTracker组件开始追踪CID。

如果分配到节点,IPFSPinadd操作被执行。

PinTracker会等待IPFSPinadd操作完成,如果Pin出现错误则会进行上报处理。

这两个阶段是异步处理的,ClusterPin阶段处理后就会给用户返回应答,IPFS-Pinning阶段处理比较慢,由PinTracker对Pin过程进行管理。如果IPFSPin失败,或Pin超时失败,Cluster会接收异常情况,并定期运行Recover功能来进行异常处理。

▲?Consensus共识组件

共识组件主要职责:

管理全局Pinset集合,包括从其它节点获取或者向其它节点发送Pin操作命令。

管理Pinset相关的文件在IPFS中的持久化存储。

在所有的节点间实现分布式一致,所有的节点需要收敛相同的Pinset。

管理集群节点,包括节点加入离开,设置节点间的管理机制。

设置节点信任机制,定义哪些节点可以访问本地RPC服务。

IPFS-Cluster共识组件目前有两种具体实现,基于“Raft”的强一致性分布式共识,和基于“Merkle-CRDT”的最终一致性共识。基于“Raft”的强一致性共识,对任何一个节点发起请求都会得到相同的回复,但将产生相对高的延迟;基于“Merkle-CRDT”的最终一致性共识具有更低的响应延迟,但可能会回复过期的数据,最终一致性即是经过一段时间后终会到达一致的弱一致性。

▲?基于Raft共识算法实现

(1)通过将更新直接发送到连接的每个节点来发布更新。

(2)在本地BoltDB保存所有的持久化数据。

(3)使用Raft共识来获得强一致性。集群选出一个Leader负责提交每个请求的日志,必须群集中超过一半的节点确认才能使操作有效。可以仅将追加日志合并并压缩为快照,然后将其发送给新的节点方。

(4)相信所有节点,所有节点都可以申请加入Raft集群,并且所有节点可以和其它节点进行网络通信,前提是他们都知道私有网络的ClusterSecret。

▲?基于Merkle-CRDT?实现

CRDT是Conflict-FreeReplicatedDataTypes的缩写,即“无冲突可复制数据类型”。Merkle-CRDT是IPFS-Cluster默认的共识组件实现。

(1)通过libp2p的pubsub组件来广播Pinset更新,通过DHT+Bitswap来定位并交换数据。

(2)在本地BoltDB保存所有的持久化数据。

(3)使用Merkle-CRDTs来达成最终一致性。Merkle-CRDTs是CRDT一种改进,使用Merkle-DAG作为共识的逻辑时钟,Merkle-DAG中每个Node代表一个操作,前一个操作Node作为后一个操作Node的Parent。这样不同节点间只需要对比并同步Merkle-DAG数据结构即可维持操作的一致性。Merkle-DAGs作为逻辑时钟是只增的,不能修改的。当新的节点加入时需要从RootNode开始遍历整个Merkle-DAG,当Merkle-DAG深度比较大时,这可能导致新节点加入处理流程过慢。

(4)不需要执行任何Peerset管理。通过pubsub收到“Ping”的每个对等方都被视为集群的成员。

IPFS-Cluster总结

IPFS-Cluster作为IPFS网络的附加层,通过添加分布式共识算法达到了IPFS集群存储的一致性。此方案可以将IPFS私有网络打造成高可用存储系统,也可以用来提高IPFS的稳定性。基于内部RPC的组件化设计非常适合分布式系统,整个系统可以很方便的扩展并部署到不同的节点。

当然,目前IPFS-Cluster还不支持基于文件系统的一致性存储操作,以集群形式添加的文件在IPFS中存储为Block格式,并不支持整个文件系统状态的分布式一致性维护。

作者简介

马耀耀

来自数据网格实验室BitXMesh团队研究方向:P2P网络、数据安全传输

标签:PINUSTCLULUSPIN币MustangCoinFlight Clup CoinPLUS价格

火币APP热门资讯
DEFI:科普 | 私钥是什么?它和你的加密资产有何关联?

私钥在密码货币的世界里是最敏感、最重要的东西。我们建议所有有志成为老手的用户学学私钥的本源、相关推理和作用。在本文中,我们会解释私钥是怎么来的,它跟你的密码学货币资产有何关联.

1900/1/1 0:00:00
ripple:Ripple合作伙伴Mercury FX纳入南非监管沙箱

南非政府间金融科技工作组近日公布监管沙箱第一批成员,其中包括Ripple合作伙伴MercuryFX。Mercury表示,希望展示其“将汇款缩短至几分钟”的技术能力.

1900/1/1 0:00:00
数字资产:巴比特原创 | 美企债券收益率创新低,更多美国企业将购买比特币

除了十年期美国国债收益率外,美国企业发债规模和收益率也值得投资者关注。近期,高收益企业债券平均收益率首次跌破4%,创历史新低,表明市场风险偏好增强.

1900/1/1 0:00:00
STACK:云南发布区块链政策 专访云南时戳负责人:强强联合,努力做区块链的科普者和建设者

伴随着数字经济不断崛起,企业、机构的区块链应用建设如火如荼,未来,区块链建设将如何更进一步?云南又是如何发力的?带着这些疑问,我们不妨去看看.

1900/1/1 0:00:00
DOG:经历了狂热之后,社会大众对DOGE的热情有所下降

一只柴犬横空出世:狗狗币在过去一周的高涨将成为载入史册的事件。然而所有的社交媒体的数据显示,这个meme的运行可能已经结束了.

1900/1/1 0:00:00
SIGN:美联储维持零利率展望,比特币“闻讯”反弹,重回59000美元

今日,美联储主席鲍威尔在美联储会议上表示,预计今年经济将快速增长,尽管金融市场担心可能会出现更高的通胀,但仍预计在2023年之前将基准利率维持在接近于零的水平.

1900/1/1 0:00:00