ROT:区块链数据如何归档?冷热分离方案了解一下_区块链技术通俗讲解中山大学

——Part1?现状——

区块链可以视作一个在分布式环境下众多可信节点共同维护的且不可篡改的账本。在区块链系统中,数据以区块作为基本单位,区块链系统利用levelDB基于Key-Value结构的数据库存取数据,通过多节点冗余存储实现账本可信,然而随着区块链运行时间的增长,区块链的存储容量将呈线性增长,且这种数据的增长速度甚至会超过存储介质容量增长的速度,因此,区块链数据存储将成为限制区块链技术发展的重要因素。

面对这一棘手的问题,数据归档技术应运而生,什么是数据归档呢?

——Part2?什么是数据归档——

数据备份的概念大家应该是比较了解的,随着数字化的推进,企业对数据的敏感度逐渐增强,数据备份系统已经成为各大中型企业的必备系统。然而正如我们对数据归档认知的不足,企业对于数据归档的使用也不如数据备份广泛。

备份的目的是为了恢复,保证在系统出现意外情况时业务的连续进展。对于企业来说,每天产生的大量数据,其实绝大部分的使用率很低,但是,出于一些特殊原因,这些数据却必须保留以备查询。简言之,归档的目的是为了服务品质和保证数据的可管理,使得运行、维护、投入整体的成本降低,如何最大化使用存储,保证数据的访问。数据归档,即数据的使用。然而如何规范的归档数据呢?我们就得具备相应的归档原则。

中国畜牧业协会刘强德:需要建立基于区块链技术的畜牧产品追溯体系:近日,在“2020农牧数智生态发展论坛”上,中国畜牧业协会智能畜牧分会秘书长刘强德表示,应该建立产品的追溯体系。但传统的追溯体系无法解决消费者的信任危机,而是需要通过基于大数据(Bigdata),以区块链技术(Blockchain)为支撑的追溯体系。区块链的去中心化,多点分布式记账,不可篡改等特点,实现了多方共同记录溯源信息,消费者可查询验真,并且可以实现保证商业隐私的同时,支持全流程交易历史记录的审计、回溯。(农博网)[2020/11/12 12:24:22]

数据存储:无论是备份还是归档,数据的完整性必须得到保证,且需在规定时间内保证数据的安全存储。保证数据的完整性、时效性及存储的安全性。

数据易读取:虽然大部分数据重复读取可能性低,但归档系统依旧不是一个备份系统,必须保证在需要的时候能方便地读取数据。保证系统数据的可读性。

数据可扩展:由于存在不同种类的数据,且数据也是实时变化且增长迅猛,因此为满足企业需求,还应具备可扩展的要求。

王坚院士:加快推进区块链技术在工业互联网数据确权等方面的应用:中国工业互联网研究院首席科学家、中国工程院院士王坚今日在经济参考报刊文《“新基建”提速 工业互联网大数据发展迎新机遇》,文中提到,数据要素参与价值创造与分配是实现高质量发展的关键环节。要加快推进区块链技术在工业互联网数据确权、确责和交易中的应用,推动数据资产的有序流通、可信交易、合法变现。[2020/3/10]

数据合法:任何的企业系统运作都应该遵守各项规章制度,要遵守政府和行业指定的各项法律、法规及各种规章。

——Part3实现难点——

正如大家所知,区块链存在数据单向增长的特性,这样数据量的增多会导致系统磁盘空间占用率高,所以需要研发区块链专用数据归档技术,将数据进行“冷热分离”,保障系统的高效可靠运转;

另外,因为区块链是一个在分布式环境下众多可信节点共同维护的且不可篡改的账本,所以传统的数据归档技术无法解决多个节点数据归档某一范围数据而账本状态保持一致性的问题,在实际情况中还存在区块链上单一节点数据归档导致的多节点数据同步时账本状态一致性的问题。

动态 | 西班牙电信与APTE合作,试用区块链技术:西班牙电信(Telefonic)与西班牙科学技术园协会(APTE)合作,使西班牙8000家公司可以试用区块链技术。该电信公司将在APTE的52个站点上部署基于Hyperledger的区块链节点,使公司能够访问安全的去中心化区块链网络。(Total Telecom)[2020/1/9]

总结:

1.区块链存在数据单向增长,需要进行冷热分离存储;

2.分布式环境下,难以保证所有节点实时进行数据归档且保证数据状态的一致性;

3.单一节点数据归档导致多节点数据同步时状态一致性难以保证。

——Part4?数据归档的架构解读——

了解了数据归档的基本概念,那么,在区块链中它是如何运作的呢?数据归档功能的主要职责是将一部分旧的线上数据移到线下转存。对此,趣链科技提出了区块链数据归档的方法,使得整个区块链系统能在不停机情况下,将区块链数据划分为链上、链下两部分,热数据仍保留在链上,但冷数据可以存储在低成本的硬件设备上,进行动态的数据归档。而且,通过数据调度层,可以很好地实现热数据和冷数据的灵活访问,热数据直接通过平台访问,冷数据则通过归档数据浏览技术浏览。另外,每个节点可以自主、多次地对数据进行归档,从而使得系统的链上数据量维持在一个稳定水平,有效释放磁盘空间。

动态 | IBM与制药公司合作将临床记录保存在区块链上:据Cointelegraph报道,美国科技巨头IBM已与制药公司Boehringer Ingelheim合作,将临床记录保存在区块链上。两家公司之间的合作旨在测试区块链技术与临床记录保持整合是否能够提供适当水平的数据完整性、透明度和患者信息安全性,以及降低成本和自动化流程。[2019/2/13]

为更形象地讲解数据归档技术,我们以趣链数据归档为讲解内容进行:

区块链的数据归档方式是一种基于状态备份的归档方法。

简单来说,用户想要对某一个区块链节点做数据归档,必须在过去某一时刻对区块链制作一个状态快照;

进行数据归档时,可以将快照点之前所有的区块链数据进行归档转储,以实现区块链节点存储压力的减负。后续未归档第一个区块的节点成为新链的1号区块。

动态 | Raiffeisen银行子公司发行区块链银行担保:据cointelegraph报道,Raiffeisen银行的俄罗斯子公司与当地国有石油巨头Gazprom Neft合作在区块链上发行银行担保。该银行担保是为了进行涉及四方的贸易融资交易,包括Raiffeisen,Gazprom Neft,白俄罗斯Mozyr炼油厂和白俄罗斯Priorbank。[2018/11/14]

▲?数据归档流程

制作快照:

1.系统获取最近距离的快照,即比当前要做快照的区块号小的最大的高度,返回该快照的信息。若没有任何快照,则以0号区块数据为基础新建快照并作为start,其制作的高度为end。

2.快照拷贝以单纯的磁盘io拷贝一份第一步获得的账本到新文件夹,并作为后续账本操作的基础。

3.根据日志数据,遍历线上,制作到账本,且同时遍历区块的merkleRoot,保证账本的正确性。

检查快照:

遍历snashot数据库中的状态数据,重新计算出bucketTree的根哈希,与最新的区块哈希对比,以保证制作的快照与实际的账本是否一致。

数据归档:

如图,用户发起数据归档请求,要求将快照点前所有的区块链数据进行转储归档。该节点将所需转储的区块数据以及相应的交易回执等数据转储,且将本地的创世状态内容更新为之前备份得到的快照状态。

如果说区块链正常的状态变迁是状态终点不停向前更新的过程,那么数据归档就是一个区块链状态起点向终点更新的过程。下面是一个比较典型的相关数据平台应用案例:

数百家中心数据,存量数据4T,日均10GB,年均3.6T数据上链,由于链上存储通常采用SSD硬盘,导致存储成本高昂。针对此问题,我们采用定期归档的方式对链上数据进行归档,由图可见,我们采用了分段存储的方式,平台可对任意的某段数据进行归档操作并保证各节点数据状态的一致性。保证链上数据稳定在1T左右,有效地释放磁盘空间的同时,极大地降低了成本,增加了系统性能。

上述的数据归档主要是针对区块链数据,而部署在区块链上的智能合约,同样有较大的存储需求用来记录庞大的业务数据。针对于这部分数据,趣链提供了另外一种归档机制,用户仅需发起一笔带有特殊标记的交易,调用智能合约中自定义的归档函数,即可实现合约数据的转储。合约编码者可以在合约中实现任意逻辑的归档函数,以满足不同的业务需求。

——?Part5总结?——

在本片中较为详细地讲解了数据归档技术在区块链中的使用,不仅实现了数据的冷热分离存储,保证了单一节点的数据归档而保持整个区块链所有节点的账本状态的一致性,而且实现了分段存储的模式,使得数据在任意范围内被归档。

从设计角度来看,数据归档后不影响原先链上数据的正确性与连续性,而且支持不同节点、不同分区自定义归档序列的范围。

从功能角度来看,数据归档主要解决区块链链上数据的冗余问题。减少链上数据存储压力,将过期数据和历史数据进行线下的存储,突破链上存储的限制。并且,并发执行数据归档过程中的各种操作,提升了归档的效率。

从应用场景来看,数据归档适用于数据冗余存储、链式递增、时效有限等情况导致的存储资源被大量过期数据占用的痛点。对于数据归档或者区块链技术有兴趣的小伙伴,添加小助加入技术交流群,欢迎您和我们共享观点,共论区块链的无限未来~

作者简介

陈少蔚

趣链科技基础平台部文档工程师

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

区块博客

[0:15ms0-6:987ms