【Filecoin源码仓库全解析】第三章(下):存储提供方(矿工)的配置操作
欢迎大家来到第三章的下篇,经过上篇 《【Filecoin源码仓库全解析】第三章(上):存储提供方(矿工)的配置操作 》的内容阅读后,我们应该能会对Filecoin存储市场机制和市场中的各角色职能有了更深刻的认知,并且可以配置自身节点角色,成为存储提供方(矿工),参与挖矿了。
上一篇,我们讲解了如何
在工程上申请存储矿工角色,本篇,我们将深度剖析存储矿工对象的
源码结构,方便大家从根本上理解矿工的事务,并对存储矿工的生命周期做了一个总结。
3.6 存储矿工对象剖析
首先,我们来深度剖析一个存储矿工对象的
源码结构,这样便于大家从根本上理解矿工的事务。
3.6.1 StorageMinerActor
我们在链上成功注册一个新的矿工身份后,Filecoin存储市场Actor(上帝)将调用CreateMiner()方法为我们生成一个新的存储矿工实例对象(StorageMinerActor),并返回其地址,这个新的实例对象结构如下:
[/ol]3.6.2StorageMinerState
存储矿工会有自己的链上状态,仅在创建新区块时更新,并全网同步可追溯,可以理解为这是Filecoin网络为矿工们所维护的一组状态账本:
[/ol]3.6.3 Owner与Worker
存储矿工角色有两个不同的地址:
小编认为需要这样区别和设计的原因归结为八个字:各司其职,安全第一。
例如:Owner适合冷存密钥,安全级别更高,Worker常迁移和变更,安全级别更低。
如下图所示,我们可以在~./filecoin/config.json下分别获取到worker和Owner的地址数据:
注意:查询Ask订单,选择交易时一定注意用worker地址来检索
3.7 存储矿工的生命周期
画了一个脑海中的草图,方便大家理解和记忆:
如图所示,存储矿工的生命线主要有四条:
下面依次来介绍其生命周期中的这几个过程:
3.7.1 存储交易
Step1:操作节点参与链上身份注册,提交抵押与存储容量,成为一个存储矿工
Step2:创建Ask订单,与用户节点交易。
Step3:密封数据并提交复制证明(PoRep)于链上,更新订单状态,完成交易,并开启PoSt证明周期(证明期是矿工必须向网络提交空间时间证明的固定时间。)
备注:这块内容可以继续深挖,后面有时间考虑单开一章节:与FilecoinProof相关
Step4:存储矿工收集证明集合,创建PoSt,计算ProveStorage和StoragePower(算力)。
备注:在证明期内,证明集会始终保持一致。在此期间系统增加的任何扇区都将顺延至下一个证明期内。
Step5:当矿工完成他们的PoSt时,调用SubmitPoSt将其提交给网络,并伴随区块更新同步状态。
3.7.2 创建区块
当经历完存储交易的过程后,存储矿工已经具备了参与创建区块节点的竞选了,选票的生成逻辑如下所示:
[/ol]
同时,为了防止女巫攻击,选票需要被其他节点验证,同时,自身也将验证其他节点的选票:
[/ol]
创建区块之前,首先要赢得选票,令所有对等节点之间达成一致。这里涉及到预期(Expected Consensus)共识,简而言之:
是Filecoin基于拜占庭容错基础上的改进版,策略是每一轮里选举出来一名或者多名存储矿工来创建新的区块,赢选票的可能性和矿工已分配的存储(即与上文中ProveStorage、StoragePower强相关) 成比例。
备注:这块内容也可以继续深挖,后面有时间考虑单开一章节:与Expected Consensus相关
当你侥幸获得一张优胜选票时,将创建新块,结构体如下所示:
[/ol]
当完成区块创建之后,随之而来的是丰厚的上帝奖励(Filecoin 分发),具体的分发策略也处于WIP状态,目前测试网阶段是1000Filecoin /Block。
3.7.3 停止挖矿
如果需要停止采矿,矿工必须履行完所有存储订单(即:名下所有Ask订单状态为Poster),并在PoSt提交期间将其从证明集中删除。
之后,可通过客户端指令调用DePledge()来取回他们的抵押品,并停止挖矿进程。
备注:此过程也会参与链上操作。
3.7.4 失责惩罚(WIP)
如果矿工因未能按时提交PoSt而被slashed,他们将失去所有抵押品。
备注:官方仍在Work in Process之中,需要更多社区的建议和讨论,目前设置了多种保险和重新验证机制,可见Filecoin也非常重视矿工的利益。
参考文献:
本章是一个基础铺垫,深挖了底层的原理,这是为了让我们对Filecoin系统的理解,不光只停留在工程指令集的操作上面。
我们将在下一章《【Filecoin源码仓库全解析】第四章(下):存储需求方的配置操作》中重点介绍存储需求方(用户)的配置操作,并反过来验证第三章中存储矿工后续挖取新块的过程,帮助大家融会贯通,并在工程上验证整个挖矿行为的生命周期。
本章赞助品牌:
搜搜IPFS:专注于IPFS生态的垂直媒体。内容涵盖IPFS的行业资讯、新闻动态、项目评测、人物专访等。我们努力为IPFS用户们创造更丰富,更有趣,更靠谱的媒体服务,致力于成为IPFS爱好者服务的媒体。目前已成为华中区最大、最具影响力的IPFS垂直媒体。
感谢 搜搜IPFS (http://sosoipfs.com/) 对嘉乐SOHO的原创内容提供支持。
版权声明:
作者:bitchina.net
链接:http://www.bitchina.net/archives/1816.html
来源:比特中国
文章版权归作者所有,未经允许请勿转载。