火星链 火星链
Ctrl+D收藏火星链

ION:技术 | 链上账本数据写入慢?试试LSM

作者:

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

导读

首先问大家一个小问题?区块链的账本数据存储格式主要是什么类型的?

相信聪明的你一定知道是Key-Value类型存储。

下一个问题,这些Key-Value数据在底层数据库如何高效组织?

答案就是我们本期介绍的内容:LSM。

LSM是一种被广泛采用的持久化Key-Value存储方案,如LevelDB,RocksDB,Cassandra等数据库均采用LSM作为其底层存储引擎。

据公开数据调研,LSM是当前市面上写密集应用的最佳解决方案,也是区块链领域被应用最多的一种存储模式,今天我们将对LSM基本概念和性能进行介绍和分析。

LSM-Tree背景:追本溯源

LSM-Tree的设计思想来自于一个计算机领域一个老生常谈的话题——对存储介质的顺序操作效率远高于随机操作。

如图1所示,对磁盘的顺序操作甚至可以快过对内存的随机操作,而对同一类磁盘,其顺序操作的速度比随机操作高出三个数量级以上,因此我们可以得出一个非常直观的结论:应当充分利用顺序读写而尽可能避免随机读写。

Figure1Randomaccessvs.Sequentialaccess

蚂蚁正研发区块链新技术 或推动区块链大规模应用提前十年:6月3日消息,近日,金融科技专家Yassine Regragui在社交平台爆料称,蚂蚁集团正研发一项名为LedgerDB的新技术,比现有联盟链快至少80倍,称将区块链大规模应用时代提前至少十年。[2020/6/3]

考虑到这一点,如果我们想尽可能提高写操作的吞吐量,那么最好的方法一定是不断地将数据追加到文件末尾,该方法可将写入吞吐量提高至磁盘的理论水平,然而也有显而易见的弊端,即读效率极低,我们称这种数据更新是非原地的,与之相对的是原地更新。

为了提高读取效率,一种常用的方法是增加索引信息,如B+树,ISAM等,对这类数据结构进行数据的更新是原地进行的,这将不可避免地引入随机IO。

LSM-Tree与传统多叉树的数据组织形式完全不同,可以认为LSM-Tree是完全以磁盘为中心的一种数据结构,其只需要少量的内存来提升效率,而可以尽可能地通过上文提到的Journaling方式来提高写入吞吐量。当然,其读取效率会稍逊于B+树。

LSM-Tree数据结构:抽丝剥茧

图2展示了LSM-Tree的理论模型(a)和一种实现方式(b)。LSM-Tree是一种层级的数据结构,包含一层空间占用较小的内存结构以及多层磁盘结构,每一层磁盘结构的空间上限呈指数增长,如在LevelDB中该系数默认为10。

支付宝爱心捐赠平台引入区块链技术 目前已支撑20亿次交易:金色财经报道,4月16日下午14:00,蚂蚁区块链“开放联盟链”面向中小企业和开发者发布,助推全民入链。蚂蚁区块链平台产品部总经理金戈在会上指出,支付宝一直在内部推动区块链的应用,促进解决行业问题。其中之一就是支付宝爱心捐赠,支付宝公益其实已经做到了很大规模。在过去从捐款人到募捐方到分发受捐的个体信息是不透明的,为了解决捐款传递流转中的问题,支付宝爱心捐赠引入区块链技术,将参与其中的多家信息写到链上,做到不可篡改,从而使得公益更加透明,截至目前该平台已经支撑了20+亿次的交易。[2020/4/16]

Figure2LSM与其LevelDB实现

对于LSM-Tree的数据插入或更新,首先会被缓存在内存中,这部分数据往往由一颗排序树进行组织。

当缓存达到预设上限,则会将内存中的数据以有序的方式写入磁盘,我们称这样的有序列为一个SortedRun,简称为Run。

随着写入操作的不断进行,L0层会堆积越来越多的Run,且显然不同的Run之前可能存在重叠部分,此时进行某一条数据的查询将无法准确判断该数据存在于哪个Run中,因此最坏情况下需要进行等同于L0层Run数量的I/O。

为了解决该问题,当某一层的Run数目或大小到达某一阈值后,LSM-Tree会进行后台的归并排序,并将排序结果输出至下一层,我们将一次归并排序称为Compaction。如同B+树的分裂一样,Compaction是LSM-Tree维持相对稳定读写效率的核心机制,我们将会在下文详细介绍两种不同的Compaction策略。

社科院研究员:采用区块链技术 为关联中小企业协助融资:中国社科院经济所副研究员林盼撰文指出,特殊时期,可鼓励国企或知名民企发挥龙头作用,积极采用区块链技术,解决信息共享过程中的隐私保护、数据确权问题,为关联中小企业增信,协助融资。政府也应进一步加强与企业、行业组织、产业园区之间的协同合作,构建政府、企业、银行和保险公司共同应对疫情、促进中小企业发展的生态系统,谋求多方共赢,携手度过难关。(光明日报)[2020/3/19]

另外值得一提的是,无论是从内存到磁盘的写入,还是磁盘中不断进行的Compaction,都是对磁盘的顺序I/O,这就是LSM拥有更高写入吞吐量的原因。

Levelingvs.Tiering:一读一写,不分伯仲

LSM-Tree的Compaction策略可以分为Leveling和Tiering两种,前者被LevelDB,RocksDB等采用,后者被Cassandra等采用,称采用Leveling策略的的LSM-Tree为LeveledLSM-Tree,采用Tiering的LSM-Tree为TieredLSM-Tree,如图3所示。

Figure3两种Compaction策略对比

▲Leveling

动态 | 上海国际医药供应链信息服务平台揭牌,采用区块链技术 实现信息溯源:上海国际贸易单一窗口“区块链+”新闻发布会11月7日上午在国家会展中心(上海)举行。会上,上海市商务委(上海市口岸办)会同上海市药监局联合打造的上海国际医药供应链信息服务平台正式揭牌。这是上海国际贸易单一窗口针对单一垂直行业进行深度服务的首个平台。

据介绍,该平台采用区块链技术,实现了分布式账本、数据防篡改和信息可追溯,为进口医疗器械和药品等行业上下游企业提供从源头到消费的“端到端”、“可视化”供应链信息服务,提高了监管效率和精准度、有效减低监管成本和企业负担。[2019/11/7]

简而言之,Tiering是写友好型的策略,而Leveling是读友好型的策略。在Leveling中,除了L0的每一层最多只能有一个Run,如图3右侧所示,当在L0插入13时,触发了L0层的Compaction,此时会对Run-L0与下层Run-L1进行一次归并排序,归并结果写入L1,此时又触发了L1的Compaction,此时会对Run-L1与下层Run-L2进行归并排序,归并结果写入L2。

▲Tiering

反观Tiering在进行Compaction时并不会主动与下层的Run进行归并,而只会对发生Compaction的那一层的若干个Run进行归并排序,这也是Tiering的一层会存在多个Run的原因。

▲对比分析

相比而言,Leveling方式进行得更加贪婪,进行了更多的磁盘I/O,维持了更高的读效率,而Tiering则相正好反。

本节我们将对LSM-Tree的设计空间进行更加形式化的分析。

声音 | 李小加:北向通有望使用区块链技术 不过现阶段难言是否成功:据雅虎财经消息,港交所行政总裁李小加表示,为提升港交所科技技术,港交所早前已投资一家深圳初创技术公司,未来或会再作收购。 李小加续指,国际投资者使用北向通进行交易是使用“T+0交易机制”,而大部份国际市场则是“T+2交易机制”,让投资者面对很大挑战。他又透露,北向通有望使用区块链技术,解决两个机制时差上的分歧,不过现阶段难言是否可成功。[2019/4/1]

LSM层数

布隆过滤器

LSM-Tree应用布隆过滤器来加速查找,LSM-Tree为每个Run设置一个布隆过滤器,在通过I/O查询某个Run之前,首先通过布隆过滤器判断待查询的数据是否存在于该Run,若布隆过滤器返回Negative,则可断言不存在,直接跳到下个Run进行查询,从而节省了一次I/O;而若布隆过滤器返回Positive,则仍不能确定数据是否存在,需要消耗一次I/O去查询该Run,若成功查询到数据,则终止查找,否则继续查找下一个Run,我们称后者为假阳现象,布隆过滤器的过高的假阳率会严重影响读性能,使得花费在布隆过滤器上的内存形同虚设。限于篇幅本文不对布隆过滤器做更多的介绍,直接给出FPR的计算公式,为公式2.

其中是为布隆过滤器设置的内存大小,为每个Run中的数据总数。读写I/O

考虑读写操作的最坏场景,对于读操作,认为其最坏场景是空读,即遍历每一层的每个Run,最后发现所读数据并不存在;对于写操作,认为其最坏场景是一条数据的写入会导致每一层发生一次Compaction。

核心理念:基于场景化的设计空间

基于以上分析,我们可以得出如图4所示的LSM-Tree可基于场景化的设计空间。

简而言之,LSM-Tree的设计空间是:在极端优化写的日志方式与极端优化读的有序列表方式之间的折中,折中策略取决于场景,折中方式可以对以下参数进行调整:

当Level间放大比例时,两种Compaction策略的读写开销是一致的,而随着T的不断增加,Leveling和Tiering方式的读开销分别提高/减少。

当T达到上限时,前者只有一层,且一层中只有一个Run,因此其读开销到达最低,即最坏情况下只需要一次I/O,而每次写入都会触发整层的Compaction;

而对于后者当T到达上限时,也只有一层,但是一层中存在:

因此读开销达到最高,而写操作不会触发任何的Compaction,因此写开销达到最低。

Figure4LSM由日志到有序列的设计空间

事实上,基于图4及上文的分析可以进行对LSM-Tree的性能进一步的优化,如文献对每一层的布隆过滤器大小进行动态调整,以充分优化内存分配并降低FPR来提高读取效率;文献提出“LazyLeveling”方式来自适应的选择Compaction策略等。

限于篇幅本文不再对这些优化思路进行介绍,感兴趣的读者可以自行查阅文献。

小结

LSM-Tree提供了相当高的写性能、空间利用率以及非常灵活的配置项可供调优,其仍然是适合区块链应用的最佳存储引擎之一。

本文对LSM-Tree从设计思想、数据结构、两种Compaction策略几个角度进行了由浅入深地介绍,限于篇幅,基于本文之上的对LSM-Tree的调优方法将会在后续文章中介绍。

作者简介叶晨宇来自趣链科技基础平台部,区块链账本存储研究小组

参考文献

.O’NeilP,ChengE,GawlickD,etal.Thelog-structuredmerge-tree(LSM-tree).ActaInformatica,1996,33(4):351-385.

.JacobsA.Thepathologiesofbigdata.CommunicationsoftheACM,2009,52(8):36-44.

.LuL,PillaiTS,GopalakrishnanH,etal.Wisckey:Separatingkeysfromvaluesinssd-consciousstorage.ACMTransactionsonStorage(TOS),2017,13(1):1-28.

.DayanN,AthanassoulisM,IdreosS.Monkey:Optimalnavigablekey-valuestore//Proceedingsofthe2017ACMInternationalConferenceonManagementofData.2017:79-94.

.DayanN,IdreosS.Dostoevsky:Betterspace-timetrade-offsforLSM-treebasedkey-valuestoresviaadaptiveremovalofsuperfluousmerging//Proceedingsofthe2018InternationalConferenceonManagementofData.2018:505-520.

.LuoC,CareyMJ.LSM-basedstoragetechniques:asurvey.TheVLDBJournal,2020,29(1):393-418.

标签:TREERUNINGIONTREES币rune币今日价格lingose币价格IONZ

以太坊最新价格热门资讯
COI:科普 | 如何理解Filecoin代币的循环供应?

这篇博客文章旨在揭示Filecoin代币如何进入循环供应,提供更多各种利益相关者如何参与其经济的见解,并阐明了如何了解和思考Filecoin代币经济学.

1900/1/1 0:00:00
OIN:深度 | 企业破产清算中的区块链应用思考

本文来源:未央网,作者:黄锐引言2020年,受到新冠肺炎疫情影响,全球经济陷入低迷。据Statista数据分析显示,2020年美国已经有400多家大型企业宣布破产,这已是十年来最糟糕的数据.

1900/1/1 0:00:00
虚拟币:证券日报 | 比特币价格突破2万美元背后:散户大量涌入,多家交易平台陷入卡顿或宕机

来源:证券日报?记者:邢萌专家提醒,比特币价格容易受庄家、各国政府政策的影响而大幅波动,普通投资者不要盲目跟风炒作“比特币价格破2万美元,创历史新高!”12月16日晚,这一突发行情令币圈沸腾.

1900/1/1 0:00:00
COM:Compound Finance创始人:CeFi必将拥抱DeFi

在一次DeFi峰会的发言中,CompoundFinance创始人RobertLeshner相信CeFi将拥抱DeFi.

1900/1/1 0:00:00
比特币:尽管比特币处于盘整中,但交易员仍看涨后市

除了在12月1日进行了一次短暂的18100美元的测试外,比特币(BTC)市场在一周内保持了相对平静。这表明,投资者开始意识到,在自去年10月以来上涨77%之后,比特币可能会出现更长的盘整期.

1900/1/1 0:00:00
比特币:摩根大通高管:对比特币的立场比较温和,但我们一直支持区块链

这家跨国投资银行批发支付负责人TakisGeorgakopoulos表示,与公众的看法相反,摩根大通一直是支持区块链的.

1900/1/1 0:00:00