Blockscout项目中地址交易列表加载性能优化分析
2025-06-17 00:11:07作者:裘晴惠Vivianne
在区块链浏览器Blockscout的使用过程中,我们发现当查询某些智能合约地址的交易历史时,页面加载速度异常缓慢。经过深入分析,这个问题源于PostgreSQL数据库查询优化器选择了不合适的索引策略,导致查询效率低下。
问题背景
Blockscout作为区块链生态中广泛使用的区块链浏览器,需要高效地处理大量交易数据的查询请求。特别是在查询具有以下特征的地址时,性能问题尤为突出:
- 目标地址是智能合约地址
- 该地址有大量历史交易记录
- 这些交易都发生在较早的区块高度
技术分析
通过执行计划分析,我们发现当前查询语句使用了以下执行路径:
EXPLAIN SELECT * FROM transactions
WHERE to_address_hash='\xa45b42a4855ac5cfefc64fd7079da6416511ec22'
ORDER BY block_number DESC limit 51;
查询优化器选择了transactions_block_number_index索引进行反向扫描,然后对结果进行过滤。这种执行计划对于具有大量历史交易的地址效率极低,因为:
- 需要扫描大量不相关的区块数据
- 然后对每条记录进行地址匹配过滤
- 整个过程可能需要超过1分钟才能完成
优化方案
实际上,数据库中已经存在一个更适合此类查询的复合索引:
"transactions_to_address_hash_with_pending_index_asc"
btree (to_address_hash, block_number, index, inserted_at, hash DESC)
这个索引的结构完全匹配我们的查询条件:
- 首先按地址哈希过滤
- 然后按区块号排序
- 其他字段确保索引的唯一性
如果查询优化器能够选择这个索引,查询效率将大幅提升,因为:
- 直接定位到目标地址的所有交易
- 按区块号降序排列
- 只需读取前51条记录即可返回结果
解决方案建议
针对这个问题,我们建议采取以下优化措施:
-
查询重写:修改API端点中的查询语句,使用更明确的语法提示优化器选择正确的索引
-
索引提示:在PostgreSQL中通过设置
enable_indexscan等参数强制使用特定索引 -
统计信息更新:确保数据库的统计信息是最新的,帮助优化器做出更好的决策
-
复合索引优化:考虑调整现有复合索引的字段顺序,使其更符合常见查询模式
性能影响
实施优化后,预期性能提升将非常显著:
- 查询响应时间从分钟级降低到毫秒级
- 数据库服务器负载降低
- 用户体验大幅改善
结论
数据库索引选择是影响区块链浏览器性能的关键因素。通过深入分析查询模式和索引结构,我们可以显著提升Blockscout在处理大量历史交易查询时的性能。这种优化不仅解决了当前报告的具体问题,也为处理类似场景提供了参考方案。
登录后查看全文
热门项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
LongCat-AudioDiT-1BLongCat-AudioDiT 是一款基于扩散模型的文本转语音(TTS)模型,代表了当前该领域的最高水平(SOTA),它直接在波形潜空间中进行操作。00- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
HY-Embodied-0.5这是一套专为现实世界具身智能打造的基础模型。该系列模型采用创新的混合Transformer(Mixture-of-Transformers, MoT) 架构,通过潜在令牌实现模态特异性计算,显著提升了细粒度感知能力。Jinja00
FreeSql功能强大的对象关系映射(O/RM)组件,支持 .NET Core 2.1+、.NET Framework 4.0+、Xamarin 以及 AOT。C#00
项目优选
收起
deepin linux kernel
C
27
14
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
659
4.26 K
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.54 K
894
Ascend Extension for PyTorch
Python
503
609
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
391
286
暂无简介
Dart
905
218
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
69
21
昇腾LLM分布式训练框架
Python
142
168
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
939
862
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
1.33 K
108