首页
/ Prysm项目v6.0.4版本技术解析:PeerDAS与轻客户端支持的重大进展

Prysm项目v6.0.4版本技术解析:PeerDAS与轻客户端支持的重大进展

2025-06-15 08:47:29作者:袁立春Spencer

Prysm是区块链2.0信标链的一个主流客户端实现,由Prysmatic Labs团队开发维护。作为区块链从工作量证明(PoW)转向权益证明(PoS)的关键基础设施,Prysm客户端承担着验证者节点运行、区块提议和验证等重要功能。本次发布的v6.0.4版本虽然是一个小版本更新,但在PeerDAS(Peer-to-Peer Data Availability Sampling)和轻客户端支持方面取得了显著进展,同时修复了若干关键问题。

核心功能增强

PeerDAS技术实现

PeerDAS是区块链扩容路线图中的重要技术,旨在通过点对点数据可用性采样来提高网络的数据处理能力。在v6.0.4版本中,开发团队实现了多项PeerDAS相关功能:

  1. 数据列侧车验证:新增了对数据列侧车(data column sidecars)的验证方法,这是PeerDAS架构中的关键组件,负责确保数据的可用性和正确性。

  2. 文件系统支持:实现了数据列侧车的文件系统存储方案,为后续的大规模数据存储和处理奠定了基础。

  3. P2P网络层:完成了PeerDAS的P2P网络实现,使得节点间能够高效地交换数据可用性信息。

  4. 区块链集成:将PeerDAS功能深度集成到区块链核心包中,确保其与现有共识机制的兼容性。

  5. 重构重建管道:优化了数据重建管道,当没有可用数据列时能够快速退出,提高了系统效率。

轻客户端支持

轻客户端是区块链生态中的重要组成部分,它们不需要同步完整的区块链数据,而是依赖全节点提供必要的信息。v6.0.4版本在轻客户端支持方面取得了以下进展:

  1. 主网规范测试:新增了对轻客户端的主网规范测试,确保实现符合区块链主网要求。

  2. 请求/响应域支持:实现了轻客户端特有的请求和响应域处理逻辑。

  3. 最小规范测试:增加了对轻客户端"update_ranking"测试的支持,这是轻客户端功能验证的重要环节。

关键问题修复

  1. Blob缓存大小设置:修复了启动时Blob缓存大小设置不正确的问题,现在能够根据当前槽时间准确初始化缓存大小。

  2. 验证器数据库导出:解决了当验证器数据库位于嵌套文件夹(如data/direct/)时,历史导出功能失效的问题。

  3. API端点行为修正:调整了/eth/v1/beacon/states/{state_id}/committees端点的行为,当请求的槽不属于指定epoch时,现在会正确返回400错误,符合Beacon API规范。

  4. Docker镜像优化:在Prysm的Docker镜像中添加了/bin/sh/bin/bash的符号链接,提高了容器兼容性。

  5. 验证器构建注册:移除了验证器上下文的过早取消操作,解决了偶尔导致验证器构建注册失败的问题。

测试网络与规范更新

  1. Hoodi测试网络:将默认gas限制提高到60M gas,为更复杂的智能合约交互提供了空间。

  2. 规范测试更新:将规范测试升级到v1.6.0-alpha.0版本,保持与最新区块链规范的同步。

  3. Electra支持:更新了Beacon API评估器,新增了对Electra升级引入的端点的支持。

技术架构改进

  1. 追踪增强:在OpenTelemetry追踪span中添加了Prysm构建数据,便于监控和调试。

  2. 测试依赖优化:解决了测试工具包中的循环依赖问题,提高了代码的可维护性。

  3. 夜间测试向量:新增了下载夜间测试向量的能力,便于开发者获取最新的测试用例。

总结

Prysm v6.0.4版本虽然在版本号上是一个小更新,但在技术实现上却包含了多项重要进展。特别是PeerDAS相关功能的持续推进,为区块链未来的扩容奠定了基础。轻客户端支持的不断完善也将有助于提升整个区块链生态的轻量级访问能力。同时,多个关键问题的修复进一步提升了客户端的稳定性和可靠性。这些改进共同推动着Prysm客户端向着更高效、更稳定的方向发展,为区块链网络的持续演进提供了坚实的技术支撑。

登录后查看全文
热门项目推荐

项目优选

收起
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
152
1.97 K
kernelkernel
deepin linux kernel
C
22
6
ops-mathops-math
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
494
37
communitycommunity
本项目是CANN开源社区的核心管理仓库,包含社区的治理章程、治理组织、通用操作指引及流程规范等基础信息
323
10
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
145
191
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
991
395
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
193
277
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
937
554
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Python
75
70