AIN:Algorand Co-Chain技术解读-ODAILY

1.ALGORAND非许可链版本

区块链的前景和挑战

透明、不可篡改和素不相识者之间的信任,这些是公有非许可区块链的基础。然而,在技术发展不足的情况下,区块链多年来一直是人们梦寐以求的实现目标。

ALGORAND非许可区块链

Algorand提供真正去中心化、可扩展和安全的非许可区块链。它具备真正去中心化的特点:每个代币都可以参与共识协议,与任何其他代币具有相同的权力。它具有可伸缩性,因为它只需使用少量的运算,即可支持数十亿用户在几秒之内生成一个区块。而且它很安全,因为它不可能被少数矿工或受托人或者一小部分代币的所有者破坏。事实上,只要Algorand区块链的大多数代币掌握在可靠的人手中,它就能保证正常工作。

Algorand协议依赖于全新的技术,例如其独特的密码抽签和超高效的拜占庭协议。

除了完全的去中心化、可扩展性和安全性之外,Algorand非许可区块链还具有以下显著特性:

无分叉和即时交易确认。Algorand区块链不会分叉。每个新区块都是单独商定的,并且保证永远留在Algorand链上。因此,用户可以立即信赖新区块中包含的交易,而不必等待区块在链中具有足够的深度。

在Layer1处理标准资产和智能合约。区块链在不同的层面上处理不同的交易。第1层是最直接和最安全的一层。传统意义上来说,第1层只处理普通支付和共识协议本身,新资产的发行、智能合约和其他的所有事务都在第2层处理。但众所周知,第2层的协议速度慢、成本高并且容易出错。相比之下,Algorand在第1层还会处理标准资产和大量智能合约的发行,包括资产代币化、原子交易和抵押借贷,并且能够在必要时隔离和收回有争议的交易。事实上,Algorand在第1层就满足了智能合约的大多数当前用例,并且具有与普通支付手段相同的安全性和效率。

2.ALGORAND许可链版本

许可型区块链的主要优点是能够保护交易不受外界干扰。

在Algorand的非许可链版本中,每个原生代币都可以参与共识协议,并具有与其他代币相同的权力。但是,在Algorand的许可链版本中,企业E只能将给定的10M代币池用于共识协议,并以任何方式将其划分到自己选择的验证节点集合V中。例如,E可以选择V仅包含5个验证节点,并为每个验证节点分配2M共识代币。这样做的结果是,E为五个验证节点中的每一个提供了生成新区块的相同能力。另举一例,E可以选择55个验证节点,为前5个验证节点每个分配1M代币,并为另外50个验证节点每个分配100K代币。这样的话,E为前5个验证节点分配的区块生成能力就是其他50个验证节点的10倍。

跨链桥Wormhole新增支持Algorand:5月17日消息,跨链桥Wormhole新增支持Algorand区块链,Wormhole此前已集成Avalanche、Terra和Polygon等网络。(CoinDesk)[2022/5/17 3:23:05]

Algorand的许可型版本具有极细的颗粒度级别,可以为不同的验证节点分配不同的权重。

通过Algorand许可区块链,而不是从头开始构建自己的许可链或采用另一个许可链,E获得了以下主要优势:

a)按需分配的加权去中心化。选择任意数量的验证节点是至关重要的。实际上,E可能想做出这种选择来提高自己区块链的安全性,或者扩大它所服务的社区。最初为少量金融机构服务的区块链可以从少量的验证节点开始。但是,如果以后它想要为中小型银行和信用合作社服务,而所有这些机构都希望参与区块生成,该怎么办?适用于少数参与者的共识算法可能无法有效地适用于成百上千的参与者。而中途改变策略可能相当具有挑战性!通过允许共识协议扩展到数十亿个验证节点,E能够保证在任何时候毫无问题地扩大验证节点集。缩小规模容易,扩大规模就难了。

b)交易最终性和第1层智能合约。无论是私有还是公有区块链,许可型还是非许可型区块链,对于任何区块链来说,交易最终性都是一个至关重要的属性。在第1层处理大多数智能合约需求的能力也是如此。通过在Algorand中增加权限控制特性,E从而获得一个许可型区块链,该区块链会自动继承这些至关重要并且很难拥有的属性。

c)可升级性和持续创新。无论何时将升级改进和创新添加到核心的无许可型Algorand主链,使用许可型版本的Algorand协议均会自动为E提供未来的升级改进和创新。

3.ALGORANDCo-Chain:定义和挑战

定义

AlgorandCo-Chain是特殊的Algorand许可链版本。因此,它是一个可扩展的许可链框架,可按需实现去中心化,具有交易即时确认和第1层智能合约等特性。它还满足一个额外的关键特性:

(d)与其他Co-Chain的互操作性。许可型区块链能让给定范围内的用户安全地进行互动。但它可能不允许他们与其他实体和个人进行互动。这是一个很大的限制,因为“外部”的世界比“内部”的世界更大,我们可能想要与更大的世界互动。一组金融机构可能想建立他们自己的许可链。但是一些医疗机构可能也想这样做。由于医疗保健是经济的重要组成部分,所以金融机构链想必希望与医疗机构链进行交互和资产交换。如果没有外部的互操作性,许可链的成员就可能被困在自己的链中。

Algorand宣布与区块链职业培训机构BlockBeam合作,以支持Gateway to Algorand计划:2月18日消息,Algorand 宣布与区块链职业培训机构 BlockBeam 合作,以支持 Gateway to Algorand 计划。此次合作的目标是开发出色的商业级区块链人才,并加速Algorand生态发展。

目前该计划仅通过申请参与,被录取的学员将通过学习、交流和协作深入了解Algorand协议。毕业的学生还将获得NFT徽章,以记录其学习情况,并随着BlockBeam生态系统的发展获得更多收益。[2022/2/18 10:01:05]

Co-Chain是Algorand许可链,它能保证Algorand无许可链与其他Co-Chain之间高效和安全的互操作性。

第一个挑战:安全性

许可链之间的互操作性很容易声明,但很难得到保证。考虑一个简单的例子。用户a拥有资产x,他希望与拥有资产y的另一用户b进行交换。

如果a和b属于Algorand无许可链或同一个AlgorandCo-Chain,此问题可以在5秒内解决,并且具有最终性和安全性。实际上,他们可以使用原子交换,这是Algorand中作为第1层交易可用的主要工具之一。但是,如果a是Co-ChainA的成员,b是另一个Co-ChainB的成员,该怎么办?

不同链间的资产交换通常通过哈希锁定协议来实现的。但是这种方法存在相当大的问题。除了需要多个逻辑复杂的步骤之外,它还容易受到拒绝服务攻击。这样的攻击可以使一方保留自己的资产,同时获得另一方的资产。为了避免这种情况,协议可能需要持续很长一段时间,这可能使拒绝服务的成本高于相关资产的价值。

第二个挑战:明确所有权

但是,这又会产生另一个问题,并且该问题适用于仅涉及x和y及其各自区块链A和B的任何协议。也就是说,由于A和B是许可型的私有链,最多只有它们的成员知道x和y交换了原始资产,因此,b现在由链A的成员拥有。如果链B损坏,没有什么能够阻止y多次向其他区块链的成员出售b或用其交换其他资产!从本质上讲,这相当于资产交换的双重支付。

如果许可链的大多数验证节点是恶意的,或者其密钥已泄露,那么该许可链就算是腐败了。在腐败的链中,原始区块可以被替换为假区块,这样就再也无法弄清楚谁拥有哪些资产。许可链的损坏具有很强的隐匿性,因为它的私密性可以防止外部人员注意到这种腐败。链的损坏是比较罕见的事件,但当它发生时,应该只影响链的成员,而不应该影响诚实链!没人能够保证另一条链可以保持诚实。但是……

动态 | Algorand基金会和意大利政府部门建立合作关系:12月16日,博科尼大学Bocconi University——Fondazione UgoBordoni(FUB)与新加坡Algorand基金会签署了一项合作协议,旨在试验和提高Algorand区块链平台的底层技术。双方的合作在政府经济发展部门主持的欧洲区块链政策组织会议期间公布,在此期间,负责经济发展部内部实体经济的Fondazione Ugo Bordoni和Algorand基金会也签署了合作协议,目的是为了测试Silvio Micali教授开发的开创性的开源技术。[2019/12/17]

链的互操作性应该保证诚实链的成员所获得的任何资产都有明确的所有权。即便从腐败的链的成员处获得的资产也是如此。

4.ALGORANDCo-Chain体系结构

现在,我们来概述一下AlgorandCo-Chain如何互操作。为简明起见,我们先忽略隐私特性。

序言

我们用MAIN来表示Algorand的主网,它是无许可并且公开的。相应地,每个Co-Chain监控MAIN的区块。对于每个Co-ChainC,MAIN维护

C的验证节点的最新列表VALIDATORSC,

以及C的成员拥有的,可以转让给其他链的所有资产的最新列表ASSETSC。

最初,当一个Co-Chain形成时,这两个列表都可能被包含在本质上是C在“MAIN中的创世区块”。

随着时间的推移,VALIDATORSC和ASSETSC都通过C在MAIN中发布由C的最新验证节点列表签署的适当交易进行更新。

需要强调的是,MAIN不仅对Co-ChainC中发生的交易一无所知,而且也不知道C的实际公钥,更不用说使用这些密钥的实际用户了!事实上,ASSETSC不会透露有关C中控制ASSETS中资产的公钥的任何信息。

从AlgorandCo-Chain到主链的资产转移

AlgorandCo-ChainA的用户x可能想要通过公钥tx将他拥有的资产a转移到MAIN。用户x这样做可能出于多种原因。例如,x可能想拍卖a,而“出价的人越多,价格就越高”。因此,与其在A上拍卖a,用户x可能更愿意在MAIN上拍卖,这样不仅有A的成员报价,还有MAIN或其他Co-Chain的成员报价。事实上,Co-Chain的任何成员都可以轻松地向MAIN转移稳定币,唯一的目的就是参加拍卖。

公告 | 币安发布Algorand(ALGO)持仓返利计划:币安发布公告称,将从2019年07月27日起支持Algorand(ALGO)的月度持仓返利计划,持仓ALGO将获得ALGO奖励。[2019/7/26]

与Co-ChainA中普通的转移相同,将a从tx转移到MAIN的操作由tx的数字签名授权,用符号表示为SIGx(tx,a,MAIN)。由于tx拥有a,并且转移得到了适当的授权,SIGx(tx,a,MAIN)会进入经A的验证节点适当认证的A的一个新区块X。此时,Co-ChainA的所有成员意识到tx和A中的任何其他公钥均不拥有资产a。因此,tx不能再授权a在A内或A外的转移。

与A的所有其他区块相同,X的结构是为了便于将SIGx(tx,a,MAIN)和转到MAIN的所有其他资产转移与所有其他信息隔离开来,这些信息必须仅对A的成员保持可见。从概念上来说,表示方式如下:

X=(SIGx(tx,a,MAIN),othertransferstoMAIN,H)

其中H是A中所有交易的单向哈希,必须在A中保持私密。需要注意的是,X的格式非常紧凑。实际上,除了打算传递给Algorand主链的信息外,它只包含256个字节。

此格式的区块X以及它在A中的证书会传播到MAIN的节点。

由于Co-ChainA运行与MAIN相同的共识算法,并且MAIN知道A的验证节点,因此MAIN的验证节点可以解析X的证书,并了解到

tx是A拥有资产a的密钥,并且

密钥tx的所有者希望将a转移到Algorand的主链。

相应地,

资产a会从ASSETSA中移除,并且

密钥tx会被记录为MAIN拥有资产a的密钥。

注意:步骤1中使用的MAIN既是公有的,也是非许可的。具体来说,MAIN为非许可型这一事实能够保证tx成为MAIN中的密钥,不会出现任何问题。并且MAIN是公有的这一事实能够保证所有人意识到资产a现在位于MAIN中。这能够保证y将获得a的明确所有权。事实上,无论Co-ChainA是否损坏,x和A中的任何其他成员均无法将a转移给任何其他Co-Chain的任何成员。

从主链转回Co-Chain的资产转移

动态 | Algorand获得风险投资基金1亿美元投资:据Coincryptorama报道,由麻省理工学院教授、图灵奖获得者西尔维奥·米卡利(Silvio Micali)创立的区块链协议项目Algorand近日获得了风险投资基金Algo Capital的1亿美元投资,用于开发支持大规模使用和高交易率的区块链的协议。据此前报道,Algorand于10月下旬已经筹集了6200万美元。[2018/12/15]

在MAIN中出售a后,tx可能会想将拍卖所得的稳定币转移给A。

更普遍的情况下,如果tx是MAIN和A两者的公钥,tx可能会想将它在MAIN中拥有的资产b转移到A。同样,这样的转移可能是由tx的数字签名授权的,用符号表示为SIGx(tx,b,A),它会进入MAIN的一个新区块。由于MAIN为非许可型,A的验证节点可能会看到SIGx(tx,a,A)出现在MAIN的区块中,或者它们可以通过tx本身看到这种出现的适当紧凑证明。无论哪种情况,A的验证节点都将导致tx成为A中资产b的当前所有者,因为它已经是A中的一个密钥。同时,只要SIGx(tx,a,A)出现在MAIN的区块中,tx便不再拥有MAIN中的b,并且ASSETSA将更新为包含资产b。

Co-Chain互操作性

接下来,我们使用上面提到的相同资产交换示例来说明Co-Chain是如何互操作的。现在,A和B是不同的AlgorandCo-Chain。具体来说,资产a在A中由公钥tx控制,其私钥为x所知,而资产b在B中由公钥ty控制,其密钥为y所知。

要交换它们的资产,x和y通过以下概念步骤利用MAIN。

1.在链A中,tx“将a转移到MAIN”,并向MAIN提供转移证明。在链B中,ty“将b转移到MAIN”,并向MAIN提供转移证明。

2.在MAIN中,tx和ty通过原子互换交换a和b。

3.在MAIN中,tx将b转移到A,并且ty将a转移到B。链A和B都能看到这两项转移。

步骤1的说明

步骤1可以通过tx在MAIN的区块中发布SIGx(tx,a,A)来实现,如上所述。相应地,在MAIN中,

资产a会从ASSETA中移除,并且资产b会从ASSETB中移除。

密钥tx不再拥有a。

类似地,对于ty来说也是如此。

步骤2的说明

从现在开始,在MAIN中,tx拥有a,并且ty拥有b,它们可以在几秒钟之内以超级安全的方式交换这些资产。实际上,所采取的方式是第1层原子交易,这是Algorand非许可链的主要功能特性之一。

步骤3的说明

如前所述,在MAIN中,tx将b转移给A中的自己,因为tx仍然是A的批准密钥。类似地,对于ty来说也是如此。

附加说明

我们可以注意到,整个过程非常快。实际上,以上三个步骤中的每一步都可以在生成新区块所需的时间内执行。这一时间在Algorand的主链中不超过5秒。但是在AlgorandCo-Chain中生成区块可能会快很多。实际上,在Algorand协议中,可以在确保大多数验证节点看到区块所需的时间内生成一个区块。在网络速度很快的Co-Chain中,这一时间可以忽略不计。

我们还注意到,整个过程发生在第1层,因此无论是在主链中还是在Co-Chain中,都具有更高的安全性。

最后请注意,给定Co-Chain的资产累计价值可能超过Algorand主链的估值。然而,Algorand的主链并不用于保护任何Co-Chain的资产。在给定的时间点,它仅用于处理给定Co-Chain的少量资产,并且仅持续几秒钟。也就是说,它用于处理Co-Chain想与另一个链交换的资产。

增强私密性

AlgorandCo-Chain之间资产交换的隐私性可以大幅增强。

具体而言,tx和ty可以是临时密钥,仅供x和y在本次资产交换中使用。也就是说,在开始上述的三步流程之前,x生成临时公钥tx并将资产a从之前持有a的任何公钥转移到tx。完成步骤3,并且tx在A中拥有资产b后,x可以将b从tx转移到他选择的任何其他公钥。通过这样的方式,Algorand的主链永远不知道A中的哪个公钥最初拥有资产a,以及哪个公钥最终会拥有b。

____________________

Algorand共识不是一个漫长的过程。随着越来越多的区块被附加到给定的区块B上,人们越来越有可能对B达成共识。Algorand单独对新的区块达成协议,这一过程完成后,再对下一个区块达成协议,以此类推。

原子交易让多名用户能够通过单笔交易交换资产,或者以多种货币执行多笔支付。因此,原子交易中的任何参与者都无法其他参与者,并且没有人害怕自己是第一个尝试的人。

另一个经常提到的选择许可型区块链的原因是安全。然而,这个理由忽略了一点,即去中心化本身就是安全性的主要来源。

*完整技术论文将于近期发布,敬请关注。

SERGEYGORBUNOV|加密部门主管

Sergey是滑铁卢大学的助理教授。他主要研究基础密码学以及大型安全系统、计算机网络、协议和区块链的设计。他于2015年获得麻省理工学院博士学位,同时也是微软博士奖学金的获奖者。他的论文主题是使用基于格的密码技术构建高级加密协议,并因此获得麻省理工学院计算机科学领域的Sprowl博士论文奖。加入Algorand之前,他曾是StealthMine的创始人兼首席技术官,并在IBMT.J.Watson研究中心工作过一段时间。

MAURICEHERLIHY

Herlihy教授是分布式计算领域的世界级专家。他曾获得2003年Dijkstra分布式计算奖、2004年哥德尔理论计算机科学奖、2008年ISCA影响力论文奖、2012年EdsgerW.Dijkstra奖和2013年WallaceMcDowell奖。他是ACM的研究员,同时还是美国发明家学院、美国国家工程学院和美国艺术与科学学院的研究员。

Herlihy教授拥有麻省理工学院的计算机科学博士学位。

SILVIOMICALI|创始人

SilvioMicali从1983年起在麻省理工学院电子工程和计算机科学系任教。Silvio主要研究密码学、零知识、伪随机数生成、安全协议以及机制设计。2017年,Silvio创办了Algorand,这是一个完全去中心化、安全、可扩展的区块链,为去中心化的经济提供了一个构建产品和服务的公共平台。在Algorand,Silvio负责监督所有的研究,包括理论、安全和加密金融。

Silvio是图灵奖、哥德尔奖和RSA奖的获得者。他是美国国家科学院、美国国家工程学院和美国艺术与科学学院的成员。Silvio在罗马大学获得了数学学士学位,并在加州大学伯克利分校获得了计算机科学博士学位。

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

金星链

SHIBKEX:多头无望,行情能再次探底吗?-ODAILY

你或许无法改变身高和体形,但是可以改变你的态度。我们每个人都有力量去培养和保持为我所用的积极态度,提高我们的人生质量,完成我们的人生目标。态度是人生理想的昭示,而非既有成果的反映.

[0:0ms0-1:26ms