宇宙链 宇宙链
Ctrl+D收藏宇宙链

区块链抽象和互操作性 2.0

作者:

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

文收录|Kazafa

原作者:JanXie?Nervos中文社区

比特币于2009年诞生后,我们很快就迎来了所谓的「山寨币」时代。人们在比特币的基础上衍生出了诸多想法,并付诸实验,一时间涌现出成千上万种加密货币。一些新的加密货币活了下来,另一些很快消失在我们的视野中。其中最成功的莫过于以太坊了。为什么是以太坊?

在以太坊之前,每当有人推出新的区块链应用,就会有一种新的「山寨币」被创造出来以实现该应用。以太坊终结了这种繁琐的创新方式,通过引入一种通用编程模型让开发者可以在其上构建任意去中心化应用。有了以太坊,开发者得以卸下编写共识代码和构建点对点网络的负担,将更多宝贵时间投入到商业逻辑上。以太坊之于其它「山寨币」就像iPhone之于它的功能手机?前辈,为我们开启了dApp的寒武纪大爆发。

回顾这段历史的时候,我们很容易理解以太坊之所以能发展成最有价值的区块链的原因——?在其它项目还在一次解决一个问题的时候,它就通过系统化的方法一举解决了成千上万个问题。而以太坊提供系统化解决方案的方法,是通过在一个不同的层级解决问题:不满足于回答如何构建下一个应用,而是要回答如何更方便的去构建接下来的一万个应用——有没有比「一个应用一条链」更好的方法?这样一种对其它「山寨币」的降维打击,开启了属于以太坊的新时代。由于开发成本大幅降低,dApp得以蓬勃发展。如今,几乎所有dApp都在以太坊上运行,这让以太坊成为加密货币的佼佼者。

常有人问:以太坊会是区块链的终极形态吗?还是说未来会出现一个新的区块链,其之于以太坊就像以太坊之于比特币一样?下一个时代会是什么样子?

以太坊的主要突破是由EVM和账户模型构成的通用编程模型,在其上开发者可以实现各类应用逻辑。智能合约模型是一个中间层,将开发者与开发应用不需要关心的区块链底层细节隔绝开来,同时又为开发者提供极好的编程灵活性。以太坊所做的事情正是抽象,如维基百科上对抽象的定义??所说:

何一:没有所谓闺蜜,Binance上币底层逻辑是寻找能够长久发展:6月4日消息,Binance 联合创始人何一在社交平台回应“闺蜜”传闻,表示没有闺蜜,但有很多号称是我闺蜜、我亲戚,CZ 朋友之流在市场极度活跃,以此拿投资额度,或者打包票上 Binance 的“资方”、闺蜜”。

此外,何一还明确 Binance 上币的底层逻辑是尽量上项目方可以活得比较久,能给用户带来回报的项目,这里其实是投研能力和审美差异的差距,哪个平台长期能识别出合适的上币项目和时机,哪个平台的用户就能活得更长久,这是平台的核心竞争力。[2023/6/5 21:15:22]

在软件工程和计算机科学中,抽象指的是:

在研究某些对象或系统时忽略其物理、空间或时间上的细节或属性,只关注更重要细节的过程。其本质上与泛化过程相似;通过复刻各种非抽象对象或系统的共同特征或属性来创建抽象概念对象。从这个角度来看,以太坊就是比特币和所谓「山寨币」的抽象。抽象是系统演化的永恒主题,在历史上发生过很多次。在编程技术的早期阶段,我们只能写着汇编代码直接与机器打交道,后来人们创造出了高级编程语言和编译器,将我们从繁琐的机器细节中解放了出来,只需关注更重要的问题。

起初,我们直接在自己的程序内管理硬件资源,后来我们构建了操作系统作为中间层,代理我们处理那些繁重的任务。再往后,我们又实现了硬件虚拟化,于是应用可以在云端运行。早期的互联网只有少数几层协议,如TCP/IP,后来发展出应用层,于是有了HTTP、FTP和SMTP等。如你所见,抽象的例子比比皆是。

因此,我想说的是,新的抽象是演化的标志,下一代区块链必须比上一代更加抽象。从比特币到以太坊的跨越是初代区块链抽象,同时我相信抽象的进程不会就此终止。如果想要知道后以太坊时代会是什么样子,我们首先应该思考的是,还可以从以太坊中进一步抽象掉什么。

数字资产管理平台Safe已实现EIP-1271兼容性:5月23日消息,数字资产管理平台Safe(原Gnosis Safe)宣布已实现EIP-1271兼容性,允许用户借助其新的签名消息功能,将这种无Gas签名流(gasless signature flow)与EIP-1271智能合约签名兼容的DApp结合使用。EIP-1271提供了一套验证代表合约账户的签名是否有效的标准,这使得合约账户能够像EOA一样进行签名验证。[2023/5/23 15:20:41]

与比特币相比,以太坊的通用智能合约模型是一大进步。若要再进一步抽象,一个方向是基于以太坊智能合约模型创建一个更抽象的模型。如果我们更深入探究以太坊模型,我们会发现该模型融入了很多特定的设计选择,其中比较主要的有:

账户地址。用户需要通过EOA来发起交易。EOA地址是公钥的?Keccak256哈希值。发送方身份验证。以太坊使用Secp256k1和Keccak256这两种特定的密码学算法对交易发送方进行身份认证。要想创建一笔有效的以太坊交易,客户端必须实现Secp256k1和Keccak256算法以签署该交易。这也导致客户端需要一种安全的方法来管理Secp256k1密钥对。密码学原语。为了给开发者提供便利,一些事先选择好的特定密码学原语被硬编码到EVM中作为预编译合约,例如,ECDSA签名验证和SHA256哈希函数。同样的算法,被硬编码到EVM中比利用Solidity实现要高效得多,前者因此获得实用性。世界状态结构。以太坊的世界状态是一个巨大的MerklePatriciaTree(MPT),账户就是叶节点。其中每个账户也以MPT的形式维护一个自己内部的键值数据库。MPT是众多可验证数据结构的选项之一。对于非技术背景的用户来说,这些设计选择看上去不明所以,但是其重要性不亚于共识算法或经济模型参数的选择。这些选择影响着以太坊的方方面面,就好像对普朗克常数?进行微调也会给我们的宇宙带来翻天覆地的变化。构建一个新的去中心化生态就像是创建一个新的宇宙,而这些设计选择就像是这个宇宙中设定好的物理规律。

区块链金融&广告互动交易所NYIAX拟于3月1日通过IPO融资1000万美元:2月25日消息,区块链金融&广告互动交易所NYIAX宣布拟于3月1日通过IPO融资1000万美元,据悉将发行1,900,000股股票。

NYIAX平台使用纳斯达克金融框架并采用纳斯达克支持的智能合约和区块链技术作为核心分类账,用于在广告行业提供金融科技服务,包括跟踪订单条款、合同管理和合同对账等。(Defenseworld)[2023/2/26 12:29:46]

当时有这些设计选择是为了帮助以太坊实现其初始目标,事后看来它们并非最佳选择。例如,发送方身份验证算法Secp256k1对设计者来说可能就是顺手一选,但是在不支持secp256k1的环境中?它带来了不必要的障碍;通过一份小小的白名单内嵌预编译合约的做法,使得大部分广泛使用中的密码学原语被排除在应用之外;状态数据结构中使用的MPT也被证明是效率非常低下?的,不仅加剧?了状态爆炸问题,还导致了与IO相关的EVM操作码?的定价困难,而定价不当可能会引发DoS攻击等安全问题。

以太坊社区和其它一些新型协议也注意到了这些问题,并尝试了不同的解决方案。例如,以太坊通过一系列硬分叉来增加更多有用的预编译合约,并对操作码重新定价;Tezos增加了Secp256r1作为新的发送方身份验证算法,等等。

问题在于,这与人们当时在「山寨币」时代解决应用需求的方式毫无区别。更麻烦的是,这些设计选择可能比应用程序更加复杂和难以理解,而且通常不存在最佳解决方案。面对不同的情况,可能会有不同的最优解。即使遇到极少数存在一般最优解的情况,我们也无法保证当下的最佳选择在将来还是如此。因此,更好的方式是,我们再次从新的层面去思考:与其继续通过需要核心团队协调的硬分叉来增加新功能,我们是否可以创建新的抽象并给予智能合约开发者充分的自由?

中移动跨元宇宙物品处理专利公布,可实现跨虚拟世界交易:金色财经报道,天眼查App显示,11月1日,咪咕文化科技有限公司、中国移动通信集团有限公司“跨元宇宙物品处理方法、装置、设备和存储介质”专利公布。专利摘要显示,所述方法包括:检测到第一虚拟世界对公有链上物品的出售请求时,确定与物品匹配的第二虚拟世界的交易链;若物品在交易链为未上链状态,则在交易链上创建物品的非同质化通证产品,并创建非同质化通证产品的在交易链上的智能合约。该发明能够实现多个虚拟世界之间的物品转移。[2022/11/2 12:10:17]

NervosCKB回答了这个问题,并创建了新抽象的层级。例如,CKB交易是抽象的,因为用户和开发者不仅限于使用默认的Blake2b-Secp256k1验证算法,任何人都能将其替换成?诸如Blake2b-Secp256r1、Keccak256-ED25519或Blake2b-SHA3-Schnorr的其他方式;CKB-VM?是抽象的,里面不包含任何预编译合约,即使是像哈希函数Blake2b和签名验证算法Secp256k1这样的默认密码学原语也只是在虚拟机中运行的智能合约,换言之,这些密码学原语与应用开发者创建的智能合约在同一个环境中运行,没有任何特权;Cell模型是抽象的,其中每个Cell只是单纯的数据存储空间,没有任何内部结构,其布局完全取决于开发者,就像我们在?sUDT?和?xUDT?看到的那样。

由于CKB在很多方面都是抽象的,开发者被赋予了更多的自由和新能力。CKB是以太坊的抽象,正如以太坊是比特币的抽象那样。抽象让CKB成为了简单却又强大的区块链,并将很多工作转移到了链下。以太坊对比特币进行抽象的结果是将开发者分成了两部分:一部分是聚焦于底层区块链的区块链开发者,另一部分是构建应用的智能合约开发者。可以预见CKB对以太坊进行抽象也会将智能合约开发者分成系统合约开发者和应用合约开发者,前者聚焦于系统级智能合约,如密码学原语、lockscript,甚至是内存管理模块。

数据:大多数区块链网络上的智能合约交互次数少于10次:金色财经报道,据Dune数据显示,大多数区块链网络上的智能合约的交互次数少于10次,尤其是BNB Chain和以太坊,其中BNB Chain的比例是97.7%(107667592),以太坊的比例为95.1%(36152963)。[2022/8/31 13:00:47]

最近以太坊社区已经认识到了区块链抽象的重要性并提出了一些相关的改进。如果这些改进得以实现,我认为它会让以太坊变得比现在更加抽象,并与其它做不到这一点的项目拉开更大的距离。然而我不认为这些关于区块链抽象的提案能让以太坊达到与CKB同等的抽象层级,因为要对一个正在运行的生态系统做如此底层的改变是极其困难的,就像我们无法在不破坏宇宙的情况下改变普朗克常数那样。例如,账户抽象会为交易池等重要模块引入新的安全复杂性——此时每当签署新的交易时,验证节点都需要处理任意计算,而非固定的签名验证。

抽象也可以从可扩展性入手。分片和Layer2解决方案都存在同样的问题,即,在某些方面改变了应用的开发方式。例如,跨分片调用?或跨Layer2交易在处理方式上可能与Layer1上的合约调用完全不同。Layer2应用开发者还可能会在不同分层上遇到不同的智能合约模型。我们该如何屏蔽这些细节,为应用开发者提供无异于Layer1的流畅开发体验?这个问题尚无定论,这是我们正在积极挑战的问题之一。

CKB上的首个通道设计,GenericPaymentChannel(GPC),就是遵循这个思路构建的。GPC旨在为Layer1上的UDT提供一个「透明的」性能扩展层,以便任何UDT从一出生就可以被「通道化」,而无需UDT开发者做任何另外的事情。在GPC中,我们为UDT开发者抽象掉了支付通道协议的细节。Godwoken和Polyjuice?是我们的另一个尝试,这两个解决方案可以认为分别是?CKB上的可扩展性和计算抽象。

每一个区块链抽象层级都会给我们带来新的东西,我们在之前的抽象层级上从未见过的东西。第一次区块链抽象为我们带来了通用可编程性和互相连接的去中心化应用。下一次区块链抽象将为我们带来什么?

互操作性2.0必将是新抽象层级孕育的果实之一。我们对数字经济未来的设想是,公有链、许可链和中心化系统都将并存。有了互操作性,我们就可以在彼此独立的系统之间转移资产并调用智能合约。近年来,人们已经进行?了很多关于互操作性?的研究和尝试?,并且相信该问题可以通过一系列互操作基础原语解决,例如多签公证、中继和哈希锁定。

虽然区块链互操作性目前在技术上是可行的,但是与具备无缝互操作性的数字经济之间还存在缺失环节。

第一,目前的互操作性尝试只会导致更加严重的网络分裂。Polkadot?和?Cosmos?等项目都定义了自己的标准,并试图围绕自己的「交换链」建立一个多链网络。此外还有努力搭建直接桥梁的项目,例如实现比特币和以太坊之间的直接跨链。我们很难想象,这些独立网络的核心团队和社区有朝一日能够坐下来共同商定出一个所有人都遵守的互操作性标准。

第二,更重要的是,即使这些区块链网络之间具备完美的技术互操作性,用户依然会被糟糕的互操作体验劝退。从用户的角度来看,如果我是一名比特币用户,想要将我的比特币转移到以太坊上参与DeFi应用,我必须先运行我的比特币钱包,发起一笔跨链交易,然后使用另外一个以太坊钱包。为了完成一次跨链操作,我必须安装两个钱包应用,保管两组助记词,使用两个地址。这个过程本身非常复杂,而且仅适用于两条区块链的情况。如果用户想要与更多区块链交互,必须管理更多助记词/地址/密钥对。用户体验问题不仅阻碍了dApp的广泛落地,还破坏了去中心化——区块链的核心价值——因为用户不得不且一定会选择中心化服务来避免所有这些麻烦。

为解决上述两个问题,我们需要一种新的互操作性,我们管它叫互操作性2.0。具备这种新型互操作性的区块链就像是一个「万维交换港」,可以在无需对方知觉的情况下实现与其它区块链的互操作。想要做到这一点,「万维交换港」就必须要能理解并执行其它区块链的协议,而非创建自己的协议并要求其它链来学习。它就好比是一个「语言通」,能主动学习并会说其他人的语言,这样就能与使用不同语言的人交流,其他人也更愿意与他交流。

在加密货币世界中,所有协议都由密码学技术构建。这也意味着「万维交换港」必须广泛支持各种密码学原语,无论其是在现在还是将来的区块链中被使用到。另外,「万维交换港」还要能理解各种钱包所签署的交易,让用户使用任意一个钱包都能够使用这个「万维交换港」上运行的一切应用。

互操作性2.0的这些需求恰好可以通过上面说的新抽象,密码学原语和身份验证来满足。这就是为什么以太坊用户可以使用MetaMask钱包操控NervosCKB上的资产和dApp?而无需进行任何手动设置,甚至不会意识到自己正在使用Nervos应用。不仅是以太坊用户,EOS、Tron以及其他区块链的用户也可以在NervosCKB上操控资产或dApp。如果当前的支持列表中没有你喜欢的区块链,不用担心,你自己就可以通过创建并部署智能合约来添加支持。这一切都可以通过编写智能合约来完成,无需请求核心开发团队和/或实行硬分叉。

在Nervos上运行的应用可以免费获得互操作性2.0带来的好处。每一个Nervos应用都可以被所有的区块链用户群体访问到,我们将这种应用称为万维应用。

作为一名开发者,你可以通过学习如何在Nervos上构建应用获得比任何其他区块链平台能提供的更广泛的用户群。作为一名用户,你只需使用现在用的顺手钱包和账户即可访问Nervos上的万维应用,无需安装新的应用或适应新的学习曲线。你可能会感觉自己在使用以太坊或EOS上的dApp,而实际上底层管道和基础设施都是Nervos提供的。我相信这才是生活应该有的样子,就像一位互联网用户在访问网站时才不会关心这个网站是用PHP还是JAVA编写的,使用的是MySQL还是PostgreSQL。用户根本不关心这些,而这才是对的。

身为开发者,我们有责任创建抽象,向用户隐藏实现细节,这样我们就可以持续的用更好的软件来取代已有的实现,从而不断提供更好的用户体验。互操作性2.0可以将加密货币世界变得像如今的互联网这样,而这需要通过新的区块链抽象来实现。

更妙的是,除了区块链用户之外,万维应用甚至可以触及一个远比区块链用户更大的群体。加密货币世界依然是个很小的圈子,我们可以「破圈」而出。区块链钱包和账户只不过是另一个账户/身份系统,而互联网世界早已确立了多种身份/账户体系和验证标准,如OpenID、人脸识别和指纹识别等。通过密码学原语和身份验证抽象,NervosCKB同样可以理解广泛使用的互联网协议。这样一来,用户就能使用浏览器和手机来访问万维应用,无需安装任何区块链钱包,无需生成密钥对,甚至无需保管任何助记词。通过这种方式,我们可以主动适应现有的互联网生态,而非创建一个全新的生态。我们的爷爷奶奶不需要费力去学习一些看起来像是魔法的东西就能享受到技术带来的便利。阻碍互联网用户进入加密货币世界的壁垒在这里不再存在。

许多现代大都市都是从贸易枢纽或港口发展而来的。威尼斯、纽约、香港、上海和新加坡都是凭借自身的港口优势而成为高度商业化的城市。在工业时代,我们利用GPS、货船和集装箱这样的互操作技术在不同城市之间转移资产。如今,我们有了加密资产、区块链和互操作性2.0。更好的互操作性会为城市带来更多移民、贸易和活力。高楼将会耸立,货物川流不息,资产在此栖息,人们在此聚集,一座新的大都市从此诞生。

标签:以太坊区块链CKBNER以太坊交易付费的成本是开发区块链数字货币ckb币是不是没救了Next Generation Network

币安app下载热门资讯
预计以太坊将在2021年征服比特币 以太坊挖|矿现在是最佳时机!

世界上第二大的加密货币旨在在2018年征服巨大的比特币。根据ZeroHedgeNews的报道,区块链技术整合了包括微软、英特尔和摩根大通在内的许多公司,以创造技术,使其他企业在系统中更容易利用以太坊区块链技术.

1900/1/1 0:00:00
币圈霸主:震荡依然在延续 多头需要修复

 既然选择了远方,便只顾风雨兼程。既然目标是地平线,留给世界的只能是背影。和阳光的人在一起,心里就不会晦暗,和快乐的人在一起,嘴角就常带微笑,借人之智,完善自己.

1900/1/1 0:00:00
华尔街为比特币吵翻天:走向主流的殿堂 还是走向投机泡沫破灭?

华尔街为比特币吵翻了天。去年比特币飙升了300%,2021年的头几周,它的价值又翻了一番,达到了6万美元的高点.

1900/1/1 0:00:00
近期热点Staking概览:老牌币式微,热点币突围

斗转星移,牛来熊往。随着Defi前奏铺路缓缓拉开本轮牛市的帷幕,各种新兴概念与技术洗刷着区块链的敏感神经.

1900/1/1 0:00:00
实战解析币圈:3-24 以太坊多空布局 斩获87个点位 明者则跟 疑者则弃

已经远去的背影,突然间变的很陌生,已经单边的行情,突然间变的很刺激,朋友间剩下了冷清和寂静,市场间留下了疯狂与喧闹.

1900/1/1 0:00:00
币上皇:日线再次出现大阳柱反转是牛市来袭的初期还是最后的疯狂

昨日以太坊极限布局,比特币同时到达最低点比特币日线来看K线图处于连续两连阳反弹,前期触底MA30而后反弹至第一区间头部57500压制,再度开始下跌,那么目前在走势上早盘再次靠近MA30开始反弹,这一段行情的走势,我会提前布局进场.

1900/1/1 0:00:00