电子发烧友网 > 区块链 > 正文

基于区块链技术的全栈开发平台ArcBlock介绍

2019年11月22日 10:39 次阅读

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

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

基于区块链技术的全栈开发平台ArcBlock介绍

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 这样的区块链平台提供了所有必要的特性,以及运行高并发、容错系统的能力,让开发者的工作变得更加轻松。
责任编辑;zl

下载发烧友APP

打造属于您的人脉电子圈

关注电子发烧友微信

有趣有料的资讯及技术干货

关注发烧友课堂

锁定最新课程活动及技术直播

电子发烧友观察

一线报道 · 深度观察 · 最新资讯
收藏 人收藏
分享:

评论

相关推荐

《Linux系统编程、网络编程》第7章 进程间通信(本机IPC)

点击右方"佳嵌"图标,可以查看所有课程。1.为什么需要进程通信;2.为什么进程空间是独立的;3.学习本章有什么意义;4.
发烧友学院发表于 2018-12-11 00:00 1186次阅读
《Linux系统编程、网络编程》第7章 进程间通信(本机IPC)

如何避免区块链项目出现市场泡沫的风险

区块链技术火热背后,另一场“盛宴”却在暗流涌动:蹭热点欺骗投资者、炒作数字货币“割韭菜”、发行“空气....
发表于 2019-11-22 10:55 0次阅读
如何避免区块链项目出现市场泡沫的风险

央行数字货币和libra对于区块链行业来说有什么...

区块链最重要的贡献,我认为就是用分布式的记账方式,通过互联网的传递加密技术的使用,使得各个账本之间保....
发表于 2019-11-22 10:51 3次阅读
央行数字货币和libra对于区块链行业来说有什么...

5G时代将推动区块链技术走进现实世界

与会专家一致认为,区块链要实现真正的繁荣必须打破,成链成本高、技术门槛高、监管难度高难题,而区块链服....
发表于 2019-11-22 10:17 39次阅读
5G时代将推动区块链技术走进现实世界

哪种加密货币挖矿方式更加有利可图

曾经接触过加密货币和区块链技术的任何人都对“挖矿”一词了如指掌。
发表于 2019-11-22 10:05 8次阅读
哪种加密货币挖矿方式更加有利可图

我们可以利用区块链实现“信任之根”吗

如果说区块链通过加密算法和数据链接,给社会带来信任,那么我认为智能合约是区块链离信任最近的一次。
发表于 2019-11-22 10:00 6次阅读
我们可以利用区块链实现“信任之根”吗

区块链在医疗卫生方面有什么影响

区块链网络和传统数据库存储数据的主要区别在于:匿名性、去中心化、不可篡改、分布式存储、多备份、数据加....
发表于 2019-11-22 09:58 6次阅读
区块链在医疗卫生方面有什么影响

区块链可以实现良好的治理吗

区块链本身是不可变的,但是如果用于保护公共代码的加密方案是很弱的,那么就会有风险。
发表于 2019-11-22 09:53 7次阅读
区块链可以实现良好的治理吗

区块链怎样做才能成为主流

我们是构建这个区块链实现未来的巨大生态系统的一部分。现在给区块链贴标签还为时过早,我们还在努力。
发表于 2019-11-22 09:48 8次阅读
区块链怎样做才能成为主流

区块链给人事行业带来了怎样的改变

区块链还能够将其他指标整合至数字资料库当中,包括认知能力、人格特质、行为、习惯甚至是从个人在线评估中....
发表于 2019-11-22 09:44 7次阅读
区块链给人事行业带来了怎样的改变

区块链领域的估值模型是怎样的

一个网络的价值等于该网络内的节点数的平方,而且该网络的价值与联网的用户数的平方成正比。
发表于 2019-11-22 09:39 9次阅读
区块链领域的估值模型是怎样的

重新思考区块链是怎样的

区块链不能替代数字化,也不应被视为数字化。在许多用例中,其他技术的成本更低,风险更低,实现速度更快。
发表于 2019-11-22 09:34 4次阅读
重新思考区块链是怎样的

EOS与Ethereum两个区块链项目有什么差别

目前以太币的通货膨胀率约为每年10%,但其目标是通过未来的网络升级将其降低到1-2%。到目前为止,还....
发表于 2019-11-22 09:31 7次阅读
EOS与Ethereum两个区块链项目有什么差别

区块链对于供应链融资确权有什么帮助

得益于去中心化、不可篡改、可追溯等优势,区块链成为银行解决供应链金融业务痛点的一大有效工具。
发表于 2019-11-22 09:25 9次阅读
区块链对于供应链融资确权有什么帮助

区块链领域中美的差异在哪里

在中国及瑞典中央银行筹备的数字货币中,区块链也作为核心技术受到关注。
发表于 2019-11-22 09:22 26次阅读
区块链领域中美的差异在哪里

区块链+ABN带来了怎样的效果

在积极探索区块链技术应用,做大应收款链平台的用户基础和交易规模的基础上,浙商银行还进一步探索推进区块....
发表于 2019-11-22 09:17 11次阅读
区块链+ABN带来了怎样的效果

区块链发展必须坚持什么原则

区块链是下一步核心技术自主创新的重要突破口,是新一轮竞争发展的重要战场。
发表于 2019-11-22 09:12 10次阅读
区块链发展必须坚持什么原则

区块链技术怎样在社会管理上发挥作用

区块链还将推动社会治理法治化。在司法、执法等领域,区块链技术与实际工作具有深度融合的广阔空间。
发表于 2019-11-22 09:06 9次阅读
区块链技术怎样在社会管理上发挥作用

金融行业的未来会不会是区块链

区块链将对在跨境支付系统以及贸易金融领域带来益处。
发表于 2019-11-22 09:02 15次阅读
金融行业的未来会不会是区块链

比特币有没有可能成为法定的数字货币

中国人民银行可能推出的数字货币是法定货币,跟区块链概念中的比特币有着本质的区别。
发表于 2019-11-22 08:57 20次阅读
比特币有没有可能成为法定的数字货币

多疑的金融从业者遇到区块链会发生什么

智能合约、分布式账本……区块链的技术名词听起来总是高大上又透着晦涩难懂。
发表于 2019-11-22 08:48 13次阅读
多疑的金融从业者遇到区块链会发生什么

区块链技术带来了什么积极的效果

已实现供应链应收账款多级融资、跨境融资、国际贸易账款监管、对外支付税务备案表等多项业务上链运行。
发表于 2019-11-22 08:45 19次阅读
区块链技术带来了什么积极的效果

腾讯区块链怎样去破局产业区块链

经过近四年的发展,腾讯区块链业务布局也从早期的注重技术研发和平台搭建,转向近两年的注重多场景应用落地....
发表于 2019-11-22 08:41 12次阅读
腾讯区块链怎样去破局产业区块链

数字货币对于中国的意义是什么

法定数字货币,即是具有法定地位、具有国家主权背书、具有发行责任主体的数字货币,央行发行的数字货币便是....
发表于 2019-11-22 08:37 17次阅读
数字货币对于中国的意义是什么

逐渐崛起的量子计算对于区块链有没有影响

因为区块链的安全性是建立在其数学运算的困难度。因此,能够以光速进行运算的量子计算机似乎对其构成了生存....
发表于 2019-11-21 15:51 40次阅读
逐渐崛起的量子计算对于区块链有没有影响

比特币P2P网络层还存在哪些问题

比特币世界的十多年历史向我们表明,比特币开发人员还有很长的路要走,而2019年3月创建的BIP 32....
发表于 2019-11-21 11:29 519次阅读
比特币P2P网络层还存在哪些问题

基于区块链技术的社区解决方案Slash Plan...

Slash Planet 已经成为 MOAC 生态合作伙伴和创始理事会理事成员单位,利用 Slash....
发表于 2019-11-21 11:23 258次阅读
基于区块链技术的社区解决方案Slash Plan...

区块链要实现真正的落地还需要解决哪些问题

CryptoSlate团队拥有美洲、欧洲、亚洲、大洋洲的研究人员、专家和记者,致力于制作最客观、透明....
发表于 2019-11-21 11:19 37次阅读
区块链要实现真正的落地还需要解决哪些问题

区块链技术为什么不能脱离密码学而单独存在

区块链最著名的应用莫过于比特币,而作为比特币的保镖,基于ECC的椭圆曲线数字签名算法(以下简称ECD....
发表于 2019-11-21 11:12 34次阅读
区块链技术为什么不能脱离密码学而单独存在

基于PoW加密货币的安全性问题探讨

Coinbase最近更改了四种不同资产确认要求,包括将比特币的区块确认从6个减至3个。本文主要阐述对....
发表于 2019-11-21 11:05 24次阅读
基于PoW加密货币的安全性问题探讨

Synthetix跟BitMex有哪些不一样的地...

但根据实际的体验情况来看,Synthetix更像去中心化版本的差价合约交易所,而由于其命脉在于发行的....
发表于 2019-11-21 11:01 24次阅读
Synthetix跟BitMex有哪些不一样的地...

修复交易延展性对BCH有什么意义

交易延展性(transacTIon malleability)源于比特币源代码中的一个错误。这个错误....
发表于 2019-11-21 10:57 25次阅读
修复交易延展性对BCH有什么意义

PoW和PoS的区别是什么

既然是传闻,我们姑且听听就好。不过说到共识机制,倒是有诸多可探讨之处。随着技术的发展和演变,当前比较....
发表于 2019-11-21 10:55 59次阅读
PoW和PoS的区别是什么

加密货币发展的十大趋势分析

CoinShares在报告的开头写道:“知识最好是共享的。”“为了加密货币产业的发展,”参与者和外部....
发表于 2019-11-21 10:52 99次阅读
加密货币发展的十大趋势分析

区块链项目中经常应用的各种编程语言介绍

数以千计的区块链项目正在开发,或者已经开发完成并且部署到了网络中。各个企业都在寻求区块链的新点子或者....
发表于 2019-11-21 10:48 38次阅读
区块链项目中经常应用的各种编程语言介绍

ASIC挖矿和GPU挖矿的特征及优势对比分析

在进入加密货币挖矿领域时,人们经常会在选择GPU或图形处理单元挖矿与ASIC专用集成电路挖矿之间选择....
发表于 2019-11-21 10:44 26次阅读
ASIC挖矿和GPU挖矿的特征及优势对比分析

区块链项目的边界在哪里

近期的区块链研讨会已经逐渐实质化,正规军进场,银行系区块链项目强劲;物流类区块链项目繁花似锦。
发表于 2019-11-21 10:10 23次阅读
区块链项目的边界在哪里

APP区块链加持供应链有什么积极的影响

随着这几年网购的兴起,各类电商融资业务如雨后春笋般崛起。从原始的商家与银行两方合作,到商家、核心企业....
发表于 2019-11-21 10:07 24次阅读
APP区块链加持供应链有什么积极的影响

区块链金融行业标准进行的怎么样了

高质量的金融发展需要高质量的金融标准。会议指出,目前金融领域还存在标准缺失、部分标准老旧等问题,金融....
发表于 2019-11-21 10:00 72次阅读
区块链金融行业标准进行的怎么样了

区块链游戏将会被怎样影响

最重要的是,网络和架构模型是实现好内容的关键。在区块链行业中,有时人们把可扩展性和去中心化当作是目的....
发表于 2019-11-21 09:56 18次阅读
区块链游戏将会被怎样影响

区块链可以用来降低金融监管的成本吗

在金融领域应用以区块链为代表的分布式记账技术,对提升监管效率和政策质量具有重要意义。
发表于 2019-11-21 09:52 26次阅读
区块链可以用来降低金融监管的成本吗

区块链国家战略一二三是怎样的情况

区块链在国内被熟知,源自以比特币为代表的加密数字货币。
发表于 2019-11-21 09:48 94次阅读
区块链国家战略一二三是怎样的情况

区块链和法律科技之间是怎样的关系

信息采集于链要通过共识,达到共识之后要存证于链,之后还有拜占廷算法,区块链被称为可信机器。
发表于 2019-11-21 09:43 937次阅读
区块链和法律科技之间是怎样的关系

假借区块链名义非法集资怎样去警惕

区块链的记账也被形象地称之为“挖矿”,也有人以挖矿为名进行诈骗。
发表于 2019-11-21 09:40 360次阅读
假借区块链名义非法集资怎样去警惕

区块链下的“空气币”有发展的空间吗

区块链不是因为能够“发币”而受追捧,区块链从来都不是为了为了“发币”而存在的。
发表于 2019-11-21 09:36 16次阅读
区块链下的“空气币”有发展的空间吗

区块链对于经济周期有没有影响

区块链诞生以来,号称能够解决信任难题,消除信息摩擦,被视为下一代技术的代表。
发表于 2019-11-21 09:33 174次阅读
区块链对于经济周期有没有影响

数字经济是怎样利用区块链的

各个国家均未实现区块链技术的大规模应用。我国的区块链技术研发致力于突破规模化可靠应用瓶颈。
发表于 2019-11-21 09:29 17次阅读
数字经济是怎样利用区块链的

一文带你解读区块链技术

区块链是各参与方基于共识机制建立数字信任的分布式共享账本,是多种技术的集成创新:基于时间戳的链式区块....
发表于 2019-11-21 09:25 35次阅读
一文带你解读区块链技术

区块链在广电上的应用怎样来推动

如果区块链技术能够成功应用于电视领域,无疑能够帮助有线电视网络运营商降低业务运营成本,提高各类业务的....
发表于 2019-11-21 09:19 20次阅读
区块链在广电上的应用怎样来推动

链改以后将会是区块链广泛的认知吗

在区块链产业要形成最广泛的共识,必然需要社会更多阶层的人认识到区块链技术的价值,并相信区块链技术会在....
发表于 2019-11-21 09:15 26次阅读
链改以后将会是区块链广泛的认知吗

虚拟货币交易所存在怎样的危机

加密货币市场不同于传统的证券市场那样层级、分工明确。
发表于 2019-11-21 09:10 124次阅读
虚拟货币交易所存在怎样的危机

加密特别提款权遇到了怎样的难题

虽然加密数字货币的发展非常迅猛,但它还处于早期阶段,很多技术不成熟,特别是在解决交易速度和系统安全上....
发表于 2019-11-21 09:06 14次阅读
加密特别提款权遇到了怎样的难题

qcow2文件的修改步骤

查看修改qcow2文件
发表于 2019-11-11 09:24 61次阅读
qcow2文件的修改步骤

物联网安全技术提高区块链应用数据的可信度

[quote]简介: 物联网设备可信上链[/quote] 物联网设备可信上链为物联网设备上链提供可信的、一站式、多层级的安全服...
发表于 2019-11-07 16:34 907次阅读
物联网安全技术提高区块链应用数据的可信度

PSOC创建者文件运行错误该怎么办?

大家好 我创建了一个新的虚拟机与Windows 10and迁移现有psoccreator项目与主机Ubuntu操作系统共享的文件夹。 我越...
发表于 2019-11-04 11:23 93次阅读
PSOC创建者文件运行错误该怎么办?

VM虚拟机开机等待1分30秒怎么解决

VM虚拟机开机时多出1分30秒的解决方案
发表于 2019-10-30 08:36 55次阅读
VM虚拟机开机等待1分30秒怎么解决

请问我该怎么操作?

1.window上IP是192.168.140.1   虚拟机上IP是192.168.43.244   开发板上IP是192.168.7.1...
发表于 2019-10-28 02:50 138次阅读
请问我该怎么操作?

请问配套的u-boot.bin可以配合不同uimage和不同的文件系统吗?

1, 目的使用nfs方式启动系统 目前nfs服务已经建立,在虚拟机上生成文件,对应的开发板上能看到。 2 设置了环境变量...
发表于 2019-10-27 23:26 99次阅读
请问配套的u-boot.bin可以配合不同uimage和不同的文件系统吗?

【瑞芯微RK1808计算棒试用体验】(1)------开发环境搭建和mobilenet_v1示例体验

瑞芯微RK1808计算棒试用体验(1)------开发环境搭建 近期收到了Elecfans论坛的超级好物---Rockchip瑞芯微RK18...
发表于 2019-10-25 18:15 170次阅读
【瑞芯微RK1808计算棒试用体验】(1)------开发环境搭建和mobilenet_v1示例体验

nfs虚拟机挂载测试出错该怎么办?

求助:nfs虚拟机挂载测试: sudo vi /etc/exports /work/nfs_root/first_fs  *(rw,sync,no_root_squash) ...
发表于 2019-10-25 05:45 127次阅读
nfs虚拟机挂载测试出错该怎么办?

为什么虚拟机和主机可以互ping,虚拟机里也可以ping通百度等网址?

按教程设置桥接网卡上网,虚拟机和主机可以互ping,虚拟机里也可以ping通百度等网址。 但是虚拟机里就是无法通过火狐...
发表于 2019-10-25 04:03 92次阅读
为什么虚拟机和主机可以互ping,虚拟机里也可以ping通百度等网址?

请问nfs虚拟机不回应该怎么办?

如图,求大神帮忙
发表于 2019-10-23 05:42 113次阅读
请问nfs虚拟机不回应该怎么办?