您正在查看: Ethereum 分类下的文章

由 Cloudflare 支持的 eth_getBlockByNumber API 的缓存代理

开源地址:https://github.com/Scratch-net/ethproxy

概述

Ethproxy 是一项为Cloudflare gateway支持的 API 方法 eth_getBlockByNumber 提供 LRU 缓存的服务。

  • 它使用CCache作为缓存引擎。
  • Singleflight可防止同时请求单个块
  • 使用envconfig进行配置
  • 最新 20 个块的默认 TTL 为 5 秒。从 20 到 1000 的区块的 TTL=“距最新的距离”* 5s
  • 所有距离最新区块超过 1000 的区块都被认为是不可变的
  • 请求过期的缓存项不会阻止服务。它在后台刷新请求的块
  • 实现优雅关闭
  • 短绒支持
  • Docker 镜像构建。由于多阶段静态构建,生成的图像大小小于 6 mb

Blob Archiver 存档并允许查询信标链中所有历史 Blob

Blob Archiver 是一种存档并允许查询信标链中所有历史 Blob 的服务。它由两个部分组成:

Archiver - 跟踪信标链并将 blob 写入存储后端
API - 实现 blob sidecars API,允许客户端从存储后端检索 blob

贮存

目前支持两种存储选项:

磁盘存储 - Blob 写入磁盘的目录中
S3 存储 - Blob 写入 S3 存储桶(或兼容服务)
BLOB_API_DATA_STORE您可以通过将和设置BLOB_ARCHIVER_DATA_STORE为file或来控制使用哪个存储后端s3。

后端s3还可以使用(例如)Google Cloud Storage 存储桶(此处的说明)。

数据有效性

目前,归档器和 API 不验证信标节点的数据。因此,信任 Beacon 节点或验证客户端中的数据非常重要。 向归档器和 API 添加数据验证存在一个未解决的问题。

开源地址:https://github.com/base-org/blob-archiver

RPCHub 聚合器

RPCHub 是一个 RPC 聚合器,通过集成您拥有的节点、私有和公共端点,为您提供最快、最强大的 RPC 服务。

RPCHub 是一款开源软件,允许您自定义自己的策略配置。

通过定制化配置,RPCHub能够实现RPC服务的可扩展、独享、稳定、低成本、高性能。

配置在本地存储和使用,以最好地保护您的隐私。

https://github.com/BlockPILabs/aggregator

invalid opcode: opcode 0x5f not defined

问题

在低版本geth(quorum)上使用高版本solidity合约和编译(0.8.20及以上),部署时报以下错误

Gas estimation errored with the following message (see below). The transaction execution will likely fail. Do you want to force sending?
Returned error: invalid opcode: opcode 0x5f not defined
OR the EVM version used by the selected environment is not compatible with the compiler EVM version.

分析

原因是因为当前版本Evm未支持eip-3855

查看代码,代码未支持 PUSH0 0x5f
https://github.com/Consensys/quorum/blob/643b5dcb8e2f0c68a8c78dc01c778a11f0ed14ba/core/vm/opcodes.go#L109-L121

const (
    POP      OpCode = 0x50
    MLOAD    OpCode = 0x51
    MSTORE   OpCode = 0x52
    MSTORE8  OpCode = 0x53
    SLOAD    OpCode = 0x54
    SSTORE   OpCode = 0x55
    JUMP     OpCode = 0x56
    JUMPI    OpCode = 0x57
    PC       OpCode = 0x58
    MSIZE    OpCode = 0x59
    GAS      OpCode = 0x5a
    JUMPDEST OpCode = 0x5b
)

对标以太坊,https://github.com/ethereum/go-ethereum/pull/24039/files
添加了对eip-3855的支持

后续

将EIP合并,并测试

类似于以太坊 infura 的服务,为 Conflux 网络提供 RPC 端点。

开源地址:https://github.com/Conflux-Chain/confura

优势

与运行全节点相比,Confura 通过提供一些增强功能,可以轻松构建高性能、可扩展且可用的 RPC 服务。

远程过程调用改进

  • 一些高频 RPC 方法(例如cfx_getStatus和 )的过期缓存cfx_epochNumber。
  • 事件日志的链外索引,通过它来处理getLogs(和cfx_getLogs)eth_getLogs,而不是直接由完整节点处理。该索引由传统数据库支持,它允许我们对更多数据进行索引和查询,而不会增加全节点上布隆过滤器所经历的误报开销。甚至可以在单个请求中检索某些合约的所有事件日志(总量小于10,000)。
  • 每个完整节点的 Pub/Sub 共享代理订阅因此可以支持更多并发会话。
  • 通过将过滤器“状态”(目前仅事件日志)的存储从完整节点迁移到我们称为“虚拟过滤器”的新后端系统的内存和数据库中,对标准过滤器 API 进行了改进,以便更可靠、可以实现高性能和更可定制(例如,过滤器更改的长轮询超时)的过滤器 API。

节点集群管理

  • 健康监控,消除最新区块高度落后于整体平均水平、心跳RPC失败或超时限制等不健康节点。
  • 通过远程 IP 地址实现一致的哈希负载平衡。
  • 通过专用节点池隔离工作负载。
  • JSON-RPC 用于管理(添加/列表/删除)节点。

速率限制

  • 用于添加/删除/管理自定义速率限制策略和 API 密钥的命令行工具集。
  • 支持使用fixed window或token bucket算法对每个 RPC 方法进行速率限制。