Elastic Rally 2.12.0 版本发布:性能测试工具的重要更新
Elastic Rally 是 Elastic 官方推出的开源性能基准测试工具,专门用于对 Elasticsearch 集群进行全面的性能测试和基准测试。它能够模拟真实场景下的搜索、索引等操作,帮助开发者评估 Elasticsearch 集群的性能表现,识别瓶颈,并进行优化。
核心升级与改进
Python 3.8 支持终止
本次 2.12.0 版本最显著的变化是移除了对 Python 3.8 的支持。这一决定反映了 Python 生态系统的自然演进,也意味着 Rally 将能够更充分地利用 Python 新版本带来的性能改进和语言特性。开发者需要确保运行环境至少升级到 Python 3.9 或更高版本。
Thespian 框架升级至 4.0.1
Rally 内部使用的分布式执行框架 Thespian 已升级到 4.0.1 版本。这一升级带来了更好的稳定性和性能表现,特别是在大规模分布式测试场景下。新版本修复了多个底层问题,提升了任务调度的可靠性。
指标索引模板处理优化
在之前的版本中,Rally 会覆盖已有的 rally-metrics 索引模板。2.12.0 版本改变了这一行为,默认会保留预先存在的索引模板。这一改进特别适合那些已经自定义了指标收集方式的用户,避免了意外的配置覆盖。
功能增强
服务器支持创建测试轨道
新版本扩展了 create-track 命令的功能,使其能够更好地支持服务器环境。这一改进使得在云原生和服务器架构下创建定制化的测试轨道变得更加便捷。
并行 JSON 日志记录
2.12.0 版本默认启用了并行 JSON 日志记录功能。这一特性为日志分析提供了更结构化的数据格式,便于后续的日志收集、分析和可视化处理。JSON 格式的日志更容易与现有的日志管理系统集成。
Docker 环境支持增强
新版本改进了对 Docker 环境的支持,特别是 esrallyd 服务现在可以原生运行在 Docker 容器中。这一改进简化了容器化部署的流程,使得在 Kubernetes 或其他容器编排系统中运行 Rally 变得更加容易。
错误修复与稳定性提升
磁盘使用统计功能改进
修复了磁盘使用统计功能只能接受单一输入的问题,现在支持传入列表形式的输入参数,提高了功能的灵活性和实用性。
日志转发优化
减少了通过 Thespian 框架转发的日志量,降低了网络开销,提升了分布式测试场景下的性能表现。
重试机制增强
为请求重试机制添加了读取超时设置,避免了某些情况下因网络问题导致的长时间等待,提高了测试的可靠性。
开发者工具改进
JSON 数据差异可视化工具
新版本引入了专门用于漂亮打印 JSON 对象及其差异的工具。这一功能极大方便了开发者在调试和测试结果分析时比较不同 JSON 数据结构。
表格驱动测试装饰器
新增了一个装饰器工具,简化了创建表格驱动单元测试的过程。这一改进提升了测试代码的可读性和可维护性,使得编写参数化测试变得更加直观。
依赖项更新
- 升级 google-auth 至 2.38.0 版本
- 升级 Jinja2 模板引擎至 3.1.5 版本
- 修复了资源读取函数的弃用警告
总结
Elastic Rally 2.12.0 版本带来了多项重要改进,特别是在分布式测试稳定性、日志记录和容器化支持方面。移除对 Python 3.8 的支持虽然是一个突破性变化,但为未来利用更现代的 Python 特性铺平了道路。新版本的工具链改进和错误修复使得 Rally 作为 Elasticsearch 性能测试工具更加成熟可靠。对于需要进行大规模 Elasticsearch 集群性能评估的团队,升级到 2.12.0 版本将获得更好的测试体验和更准确的结果。
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust099- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
MiMo-V2.5-ProMiMo-V2.5-Pro作为旗舰模型,擅⻓处理复杂Agent任务,单次任务可完成近千次⼯具调⽤与⼗余轮上 下⽂压缩。Python00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
Kimi-K2.6Kimi K2.6 是一款开源的原生多模态智能体模型,在长程编码、编码驱动设计、主动自主执行以及群体任务编排等实用能力方面实现了显著提升。Python00
MiniMax-M2.7MiniMax-M2.7 是我们首个深度参与自身进化过程的模型。M2.7 具备构建复杂智能体应用框架的能力,能够借助智能体团队、复杂技能以及动态工具搜索,完成高度精细的生产力任务。Python00