想在web3上进行构建?Nader Dabit在一份介绍性指南中指出了web3技术堆栈的构建模块 在'web3上构建'的下一章节中,Edge & Node开发者关系工程师Nader Dabit阐述了web3堆栈,以及开发者如何将在web3上构建的各个层面概念化。 我在2021年4月过渡到web3,此前我做了大约10年的传统全栈开发者。在潜心研究所有这些新技术和想法时,我想知道的第一件事是 "什么是web3堆栈?"。 当构建一个传统的网络或移动应用程序时,我经常依赖某几个构建模块来完成工作:
使用这些核心组件,我可以建立我想要的大多数类型的应用程序,或者至少可以达到大部分的目的。那么,这在web3中是什么样子的呢? 事实证明,这个问题的答案并不那么直截了当,因为:
对我来说,也更难理解如何启动、运行和建立web3应用程序,因为我是以与web2世界相同的方式来处理问题的。 在过去8个月左右的时间里,经过工作、研究、实验和建设,我想和大家分享一下我的心得。 什么是web3? 在我们定义web3堆栈之前,让我们试着定义一下web3: Web3是实现完全去中心化的应用的协议栈。 有了这个去中心化的技术栈,我们就可以开始构建去中心化的应用,这些应用有其自身的意义和特点。 web3的一些特点是:
虽然一些建立在去中心化技术堆栈上的应用程序将取代它们的前辈,但区块链启用的新源语也使新的应用程序范式成为可能。 原生的数字支付和公共后端基础设施--如机器学习、移动设备、虚拟现实和其他技术源语、平台和构建模块--使全新类型的应用程序得以建立,有些是尚未想象到的。 这是否意味着一切都将被web3取代?不一定。虽然我认为对于某些类型的应用程序来说,建立在去中心化的技术堆栈上是一个更好的选择--就像几乎任何技术决定一样,这取决于你要建立什么。 现在让我们开始深入了解web3的堆栈,分成以下几类:
区块链 有无数的区块链,你可以选择建立在其上。没有一个是 "最好的",相反,你应该考虑它们之间的各种权衡。 在学习新东西时,有一件事对我来说常常很重要,那就是将帕累托原则应用到我所学的东西上。也就是说,什么是最有效的方式来获得该数量的时间和努力的结果。遵循这个想法,我可以在最短的时间内学习新东西的同时获得最大的牵引力和动力。 在区块链领域,学习Solidity和EVM(或Ethereum虚拟机)可能是作为区块链开发者入门时的最佳选择。使用这种技能(和技术栈),你不仅可以为以太坊,而且可以为其他以太坊第二层、侧链,甚至其他区块链(如Avalanche、Fantom和Celo)构建。 也就是说,Rust在区块链领域开始变得越来越流行,Solana、NEAR、Polkadot等都有一流的Rust支持。你学习这两种语言可能都不会出错,但对于初学者来说,如果今天有人问我,我会说Solidity仍将是更好的选择。 除了这些建议,这里有一个不全面的区块链样本,它在技术、实用性、社区、势头和未来可行性方面有一个坚实的组合:
区块链开发环境 对于EVM开发,有几个好的开发环境可以使用:
对于Solana的开发,Anchor正在迅速成为新的开发者的入门点。它提供了一个CLI,用于构建和测试Solana程序的脚手架,以及你可以用来构建前端的客户端库。它还包括一个DSL,可以抽象出开发人员在开始使用Solana和Rust开发时经常遇到的许多复杂问题。 文件存储 我们在web3中把图片、视频和其他文件存储在哪里?在链上存储这么大的文件通常是非常昂贵的,所以我们可能不想把它们存储在那里。 相反,我们可以使用少数几个文件存储协议中的一个:
P2P数据库 除了文件存储和链上存储外,你可能还需要在链外存储数据。你可以使用这些类型的解决方案,类似于你在传统技术堆栈中使用数据库的方式,但它们是在去中心化的网络上的N个节点上复制的,因此更可靠(至少在理论上)。 几个选择是:
就成熟度而言,我的看法是,链外存储解决方案的生态系统还没有达到建立一些开发者可能想要的更高级的用例所需要的程度。这里的一些挑战是实时数据、冲突检测和冲突解决、写入授权、文档和一般开发者经验。 将链外数据解决方案与区块链协议相结合,是我们在拥有能够支持任何类型应用的完全去中心化协议栈之前需要跨越的最后一个大障碍之一。 API(索引和查询) 我们与区块链互动和在区块链之上构建的方式与传统技术栈中的数据库有很多不同。对于区块链,数据不是以一种可以有效或容易地直接从其他应用程序或前端消费的格式存储的。 区块链是为写操作而优化的。你经常听到以每秒交易量、区块时间和交易成本为中心的创新发生。区块链数据在一段时间内以区块形式写入,使得除了基本的读取操作外,其他的都不可能。 在大多数应用中,你需要像关系型数据、排序、过滤、全文搜索、分页和许多其他类型的查询功能。为了做到这一点,需要对数据进行索引和组织,以便有效地进行检索。 传统上,这是数据库在集中式技术栈中所做的工作,但在web3栈中缺少索引层。 The Graph是一个用于索引和查询区块链数据的协议,它使这一过程变得更加容易,并为这样做提供了一个去中心化的解决方案。任何人都可以建立和发布开放的GraphQL APIs,称为子图,使区块链数据易于查询。 要了解更多关于The Graph的信息,请查看这里(https://thegraph.com/docs/)的文档或我在这里的教程(https://dev.to/dabit3/building-graphql-apis-on-ethereum-4poa)。 身份认证 在web3中,身份认证是一个完全不同的范式。在web2中,认证几乎总是基于用户的个人信息。这些信息通常是通过一个表单或OAuth提供者收集的,要求用户交出这些信息以换取对应用程序的访问。 在web3中,身份识别完全围绕着钱包和公钥密码学的概念。 虽然 "钱包 "这个名字有它的作用,但我发现刚接触web3的人觉得这个术语很混乱,因为它与认证和身份有关。我希望将来我们能想出一些其他的方法来表达钱包是什么,因为它不仅结合了金融的各个方面,也结合了身份和信誉。 作为一个开发者,你将需要了解如何以各种方式访问用户的钱包和地址并与之互动。 在一个非常基本的层面上(也是一个非常常见的要求),你可能想请求访问用户的钱包。要做到这一点,你通常能够在窗口环境(网络浏览器)中访问用户的钱包,或者使用像WalletConnect或Solana的钱包适配器。 例如,如果他们有一个可用的Ethereum钱包,你将能够访问window.ethereum。对于Solana(window.solana)、Arweave(window.arweaveWallet)和其他少数的钱包也是如此。WalletConnect很适合移动网络和React Native,因为它允许用户直接从设备上使用他们的移动钱包进行授权。 如果你想自己处理认证,你可以让用户签署交易,然后在某处解码以认证用户,但这通常需要一个服务器。这里是一个使用EVM钱包的例子,这里是一个使用Solana / Phantom的例子。 以去中心化的方式管理用户资料呢?Ceramic Network为管理去中心化的身份提供了最强大的协议和工具套件。他们最近发布了一篇博文,概述了他们最近的一些更新,并给出了一些关于所有工具如何协同工作的指南。我想从那里开始,然后探索他们的文档,以获得对如何开始构建的理解,并考虑查看我在这里使用Ceramic self.id的例子项目。 如果你想获取一个用户的ENS文本记录,ensjs库提供了一个很好的API来获取用户数据:
SpruceID也是一个看起来很有前途的东西,但我还没有试过。 Ceramic和Spruce都实现了W3C的DID规范,这本身也是我认为是web3的一个组成部分。既然如此,任何DID的集中实现都违背了该规范试图实现的理念。 客户端 就JavaScript框架而言,你真的可以用任何你想要的东西来构建,因为客户端的区块链SDK大多是框架无关的。也就是说,绝大多数的项目和例子都是在React中构建的。还有一些像Solana Wallet Adapter这样的库,为React提供额外的工具,所以我说学习或熟悉React可能是一个明智之举。 对于以太坊的客户端SDK,有web3.js和ethers.js。对我来说,Ethers更容易接近,并且有更好的文档,尽管web3.js存在的时间更长。 在Solana,你可能会使用@solana/web3.js和/或Anchor。我发现Anchor客户端库是我构建Solana程序的首选,因为我反正也在使用Anchor框架,而且我发现它比@solana/web3.js更容易理解。
其他协议 Radicle是一个建立在Git上的去中心化的代码协作协议。它可以被认为是GitHub的一个去中心化版本。 Livepeer是一个去中心化的视频流媒体网络。它已经很成熟,并被广泛使用,网络上有超过7万个GPU的直播。 Chainlink是一个预言机,能够访问真实世界的数据和链外计算,同时保持区块链技术固有的安全性和可靠性保证。 总结 这篇文章将是我在学习、试验和收集 web3 开发人员的反馈时跟上的动态文档。 |