Solana RPC 的工作原理

文章目录

  • [Solana RPC 的工作原理](#Solana RPC 的工作原理)
    • [什么是加密中的 RPC?](#什么是加密中的 RPC?)
    • [RPC 如何在 Solana 上工作?](#RPC 如何在 Solana 上工作?)
      • [如何使用 Solana RPC?](#如何使用 Solana RPC?)
      • [如何开始使用 RPC?](#如何开始使用 RPC?)

Solana RPC 的工作原理

原文链接:https://www.helius.dev/blog/how-solana-rpcs-work

什么是加密中的 RPC?

在传统 (web2) 软件开发中,您通常通过使用 API 来获取所需的数据。您可以使用 Stripe API 处理支付数据,使用 Twilio 处理 SMS 数据,使用 Bloomberg 处理财务数据,使用 Plaid 处理银行数据,等等。

这里需要注意的有趣事情是,您正在寻找的数据通常由中心化实体控制。

在加密世界中,您需要的所有数据都在链上。它是完全无需许可的,任何人都可以查看和使用。那么如何检索它呢?使用 RPC。

RPC(虽然在技术上代表远程过程调用)通常用作 RPC 节点的缩写术语。是指参与区块链网络并公开开发人员可以调用的方法(称为远程过程调用)的节点。

RPC 如何在 Solana 上工作?

为了让 Solana 运行,它需要一个运行其软件客户端的分布式节点网络。

这些节点可以分为两种类型:验证者和 RPC。

这两个节点都有一个重要的共同点:它们都持续监视区块链并存储其最新数据(或状态)。

但是,它们之间有一个关键区别。

验证者是投票(例如:"是的,这个区块是有效的")并参与共识的节点。

RPC 是不投票的节点,但处理处理链上数据的请求。请注意,这种配置在其他区块链中并不常见,例如以太坊,其中验证器和 RPC 节点通常是相同的。

当您进行 RPC 调用时,您正在参与区块链的节点上调用过程/函数。由于它参与了网络,因此它知道最新数据是什么,并可以根据要求将其公开给您。

如何使用 Solana RPC?

要从 Solana 区块链获取数据,您必须向参与网络的 RPC 节点发出 JSON-RPC 请求

典型的 JSON-RPC 请求可能如下所示:

bash 复制代码
 curl http://localhost:8899 -X POST -H "Content-Type: application/json" -d '  { "jsonrpc": "2.0","id":1,"method":"getBlock", "params": [430, { "encoding": "json", "maxSupportedTransactionVersion":0, "transactionDetails":"full", "rewards":false } ] } 

此请求要求在 localhost:8899 中找到的 RPC 节点获取 getBlock RPC 方法。它知道在收到此请求时该怎么做,因为它正在运行 Solana 区块链的软件客户端。

在实践中,没有人真正像这样处理直接的 JSON-RPC 请求(尽管你当然可以!大多数开发人员更喜欢使用 RPC 客户端。最常用的是 Solana Web3 JS 库,可以在这里找到。要查找 Solana 上可用的 JSON RPC 方法的完整列表,请查看官方文档

如何开始使用 RPC?

RPC非常重要 - 没有它们,您实际上无法使用区块链。

因此,有些公司专门完善 RPC 体验。这些机器的使用率非常高,在高负载下表现良好对它们至关重要。一个好的 RPC 提供程序将是可靠的,具有一致的性能,并将向最终用户公开指标,以便查看其随时间推移的使用模式。在 Helius,我们是 Solana 原生工程师,我们的使命是为各种开发人员提供最佳的 RPC 体验。您只需单击此处两下即可免费开始使用,无需电子邮件注册或信用卡。这是对 Solana RPC 的非常简短且适合初学者的介绍。您可能已经知道很多这些信息。接下来,我们将讨论 RPC 优化、注意事项和一些更高级的主题------感谢您的阅读!

相关推荐
眠りたいです4 天前
基于脚手架微服务的视频点播系统-脚手架开发部分-brpc中间件介绍与使用及二次封装
c++·微服务·中间件·rpc·架构·brpc
锋风Fengfeng6 天前
基于Binder的4种RPC调用
网络协议·rpc·binder
编啊编程啊程6 天前
gRPC从0到1系列【20】
java·rpc·kafka·dubbo·nio
编啊编程啊程6 天前
gRPC从0到1系列【19】
java·spring boot·rpc·dubbo·nio
寒士obj7 天前
轻量级、高性能的RPC框架——Dubbo
网络协议·rpc·dubbo
失散137 天前
分布式专题——26 BIO、NIO编程与直接内存、零拷贝深入辨析
java·分布式·rpc·架构·nio·零拷贝
编啊编程啊程11 天前
gRPC从0到1系列【6】
java·rpc·kafka·dubbo·nio
她说人狗殊途12 天前
Spring IoC容器加载过程 vs Bean生命周期对应关系图
java·开发语言·rpc
weixin_4462608512 天前
提升开发效率的RPC系统!
网络·网络协议·rpc
H3C-Navigator12 天前
RPC在分布式存储系统中的应用
分布式·网络协议·rpc