Pegasus项目中手动压缩任务进度检测问题分析
2025-07-05 04:10:18作者:裘旻烁
问题背景
在分布式存储系统Pegasus中,手动压缩(manual compact)是一个重要的维护操作,用于优化数据存储结构。然而,近期发现pegasus_manual_compact.sh脚本中的wait_manual_compact()函数无法正确检测手动压缩任务的执行进度,导致在封装手动压缩工具时出现超时失败的问题。
问题现象
当使用命令sh pegasus_manual_compact.sh -c {meta_server_list} -a {table_name} --bottommost_level_compaction force执行手动压缩时,wait_manual_compact()函数会持续输出类似日志:
[35s] 0 finished, 8 not finished (0 in queue, 0 in running), estimate remaining unknown seconds. table [**] manual compaction is running now.
即使手动压缩任务已经完成,该函数仍会持续输出上述信息,无法正确判断任务是否真正完成。
根本原因分析
经过深入调查,发现问题的根源在于wait_manual_compact()函数无法正确解析remote_command -t replica-server replica.query-compact ${app_id}命令的输出格式变化。
在Pegasus的早期版本中,该命令输出格式为:
CALL [replica-server] [10.1.132.36:8171] succeed: 8 processed, 0 not found
4.0@10.1.132.36:8171@P : last finish at [-]
4.1@10.1.132.36:8171@P : last finish at [-]
4.2@10.1.132.36:8171@P : last finish at [-]
...
而在最新版本中,输出格式已变更为更详细的JSON格式:
CALL [replica-server] [10.1.132.34:8171] succeed:
8 processed, 0 not found
4.0@10.1.132.34:8171@P : {"last_finish":"-","last_used_ms":"-","recent_enqueue_at":"-","recent_start_at":"-"}
4.1@10.1.132.34:8171@P : {"last_finish":"-","last_used_ms":"-","recent_enqueue_at":"-","recent_start_at":"-"}
...
技术影响
- 自动化流程中断:由于进度检测失败,依赖此功能的自动化运维流程会出现异常中断
- 运维效率降低:管理员需要手动确认任务状态,增加了运维复杂度
- 资源浪费:系统可能重复执行已完成的任务,造成不必要的资源消耗
解决方案建议
- 输出格式适配:更新
wait_manual_compact()函数,使其能够同时兼容新旧版本的输出格式 - JSON解析增强:对于新版输出,应增加JSON解析逻辑,准确提取关键状态信息
- 状态判断优化:基于更丰富的状态信息(如
recent_start_at等),实现更精确的任务状态判断 - 兼容性处理:在变更期间应保持对旧版本的支持,确保平滑过渡
总结
Pegasus作为分布式存储系统,其手动压缩功能对系统性能优化至关重要。此问题的解决不仅能够修复当前的功能缺陷,还能为后续类似的功能扩展提供参考。建议在修复此问题时,同时考虑增加更丰富的状态监控指标,为系统运维提供更全面的可视化支持。
登录后查看全文
热门项目推荐
相关项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
MiniMax-M2.7MiniMax-M2.7 是我们首个深度参与自身进化过程的模型。M2.7 具备构建复杂智能体应用框架的能力,能够借助智能体团队、复杂技能以及动态工具搜索,完成高度精细的生产力任务。Python00- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
HY-Embodied-0.5这是一套专为现实世界具身智能打造的基础模型。该系列模型采用创新的混合Transformer(Mixture-of-Transformers, MoT) 架构,通过潜在令牌实现模态特异性计算,显著提升了细粒度感知能力。Jinja00
LongCat-AudioDiT-1BLongCat-AudioDiT 是一款基于扩散模型的文本转语音(TTS)模型,代表了当前该领域的最高水平(SOTA),它直接在波形潜空间中进行操作。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
504
609
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
391
288
暂无简介
Dart
906
218
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
69
21
昇腾LLM分布式训练框架
Python
142
168
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
939
863
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
1.33 K
108