当前位置:首页 > 物联网 > 区块链
[导读] ArcBlock 是谁,为什么他们喜欢 BEAM? ArcBlock 区块基石[1]肩负这样一项使命:大大简化区块链技术并将其迅速应用于日常生活之中。为此,他们开发了一个区块链全栈开发平

ArcBlock 是谁,为什么他们喜欢 BEAM?

ArcBlock 区块基石[1]肩负这样一项使命:大大简化区块链技术并将其迅速应用于日常生活之中。为此,他们开发了一个区块链全栈开发平台,为开发者提供了轻松构建、运行和部署去中心化应用(DApps)所需的一切。其平台的核心是 BEAM 虚拟机。他们全心全意信任和支持 Erlang 生态系统,并且作为创始赞助人加入了 Erlang 生态系统基金会。在这篇博文中,ArcBlock 研发副总裁陈天将谈谈他们为什么钟爱 BEAM 虚拟机以及将其用作所有希望开发 DApp 的人的基石的益处。

BEAM 和区块链简介

在构建具有高可用度、容错能力和可扩展性的实时系统方面,Erlang 是最好的编程语言之一。BEAM 是虚拟机——在我们看来也是默默无闻的英雄。BEAM 的优点也适用于在虚拟机上运行的其他语言,包括 Elixir。无论人们使用何种高级编程语言,一切都归结于 BEAM。这是技术中重要的一环,它帮助实现所有重要的百分百可用性。

如今,BEAM 为全球一半以上的互联网路由器助力,我们不认为能找到比这更有力的证明了。以下是 BEAM 的一些好处,使其极其适合打造区块链。

网络共识

将 BEAM 作为构建去中心化应用的关键组件的决定很简单。首先,区块链和去中心化应用[2]需要在网络中的所有节点上实现一致的状态。我们通过使用状态副本引擎(也称为共识引擎)来实现这一点。共识很重要,因为这种机制确保信息添加到区块链账本是有效的。为了达成共识,网络上的节点需要对信息达成一致,共识达成后,数据就可被添加到分类账中。可用的引擎很多,我们平台目前选择 Tendermint,支持状态复制引擎。

BEAM + DApps

除了共识引擎外,BEAM 是满足去中心化应用其他几个关键需求的完美解决方案。为了让去中心化应用能在我们的开发框架中工作,我们需要一个嵌入式数据库存储应用状态,以及一个用于区块链数据的索引数据库。在此过程中,我们还需要区块链节点能够监听网络上的节点,并为下一个数据区块“投票”。对于这些需求,系统需要持续的响应和可用性。

现在,需要注意的是,除了持续响应之外,我们还需要考虑 CPU 任务。特别是当系统遇到 CPU 密集型任务时,我们的区块链平台和服务不能停止工作。如果系统变得无响应,则可能发生潜在的灾难性错误。

代码热重载

除了 BEAM 的调度器,我们喜欢的另一个特性是代码热重载。它可以让你在运行中做几乎任何事情,而不需要关闭 BEAM。例如,我们的区块链应用平台附带了许多不同的智能合约,开发者可以使用这些合约使去中心化应用的功能更加丰富。然而,通过区块链,您拥有一个分布式网络,需要确保每个节点都行为一致。

在大多数情况下,开发者必须更新和重新启动他们的节点以启用最新软件,这将导致潜在的问题和不必要的宕机。通过 ArcBlock,我们利用 BEAM 的代码热重载特性,让节点在整个网络中动态地启用/禁用智能合约。这只需通过发送交易来完成,该交易告诉系统,它应该在特定的时间升级软件。当这种情况发生时,ArcBlock 将告诉 BEAM 安装新代码,然后网络中的每个节点都将拥有最新的功能。

速度是相对的

BEAM 使用“演员模型”来模拟真实世界,一切都是不可变的。因此,不需要定状态并预防竞争状况。当然,一切都是有代价的。BEAM 简单而美丽的不变性可能会导致程序运行得更慢。为了缓解这一潜在的缓慢,ArcBlock 利用 Rust 来帮助 CPU 完成密集的任务,例如为状态创建 Merkle-Patricia 树。再次强调,通过提供简单的方法来与外部世界沟通,使用 Rust 将性能提高到另一个水平,BEAM 证明了它的价值。

垃圾收集

别让这个名字欺骗你。垃圾收集是至关重要的。Erlang 使用动态内存和跟踪垃圾收集。每个进程都有自己的堆栈和堆,它们被分配在相同的内存块中,并且可以彼此增长。当堆栈和堆相遇时,垃圾收集器被触发,内存将被回收。

虽然这个解释有点技术性,但是 BEAM 的垃圾收集过程是在进程水平完成的,从而确保不会出现“让世界停止,让我清理垃圾”这类的垃圾收集。相反,它确保进程在没有任何类型的中断情况下继续运行。

OTP

最后但并非最不重要的是,Erlang 提供了一个名为 OTP 的开发套件,让开发者使用在 BEAM 世界中得到认可的最佳实践的简单方法。对于任何企业或区块链应用平台而言,围绕行业标准构建是必须的,OTP 使利用 BEAM 中开发者可用的所有优点编写代码变得容易。

容错

我们把这一点留到最后是有原因的。这是目前为止 ArcBlock 最依赖 BEAM 的特性。在区块链领域,它是使 BEAM 优于许多竞争对手的技术。尽管成千上万的交易同时发生;但系统特定部分发生的任何错误都不会影响整个节点。错误将可自我修复,使节点能够抵御不良行为或特定攻击。对于向用户交付服务或支持生产品质的应用的任何人来说,这都是一个关键特性。通过引入默认容错,我们可以确保运行在 ArcBlock 平台上的任何人都保持在线和可用。

我们相信,BEAM 虽然是多年前设计的,但其目的是用于区块链。它为开发者和像 ArcBlock 这样的区块链平台提供了所有必要的特性,以及运行高并发、容错系统的能力,让开发者的工作变得更加轻松。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭