当前位置:首页 > 物联网 > 区块链
[导读] 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 这样的区块链平台提供了所有必要的特性,以及运行高并发、容错系统的能力,让开发者的工作变得更加轻松。

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

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭