Apache Kyuubi 中查询状态提前返回但作业仍在执行的问题分析
2025-07-05 11:34:10作者:余洋婵Anita
问题背景
在 Apache Kyuubi 与 Spark 集成使用过程中,用户发现了一个特殊现象:当执行某些特定类型的 SQL 查询时,Kyuubi 会快速返回 FINISHED 状态,但实际上 Spark 作业仍在后台继续执行。这种情况主要发生在执行包含 JOIN 操作的查询时,特别是当其中一个 JOIN 表为空的情况下。
问题现象
用户提交的查询通常具有以下特征:
- 查询包含 LEFT JOIN 操作
- 左表为空(0行结果)
- 右表数据量较大(上亿行)
在这种情况下,Kyuubi 会在几秒内返回 FINISHED 状态,但实际上 Spark 仍在执行右表的相关任务,持续占用集群资源。只有当用户手动关闭操作时,这些后台任务才会被取消。
技术分析
Spark 执行机制
在 Spark 中,当执行 JOIN 操作时,如果发现其中一边为空表,理论上可以立即终止查询执行,因为结果必然为空。然而,Spark 的 Adaptive Query Execution (AQE) 优化器在某些情况下不会立即取消已经启动的任务。
Kyuubi 行为
Kyuubi 作为 Spark SQL 的网关服务,其状态判断基于 Spark SQL 的执行状态。当 Spark SQL 逻辑上已经完成(如检测到一边 JOIN 为空),Kyuubi 会立即返回 FINISHED 状态,但实际上 Spark 物理执行计划中的某些任务可能仍在运行。
REST API 的特殊情况
通过进一步分析发现,这个问题在使用 Kyuubi REST API 时尤为明显。原因是:
- REST API 会话不会自动调用 SparkOperation 的 close 方法
- 缺少对 sparkContext.cancelJobGroup 的调用
- 导致后台任务无法被及时清理
解决方案
社区已经针对此问题提出了修复方案,主要改进点包括:
- 在 ExecuteStatement 中显式调用 cancelJobGroup
- 确保 REST API 会话也能正确清理后台任务
- 完善状态判断逻辑,避免误导用户
最佳实践
对于使用 Kyuubi 的用户,建议:
- 对于已知会产生空结果的查询,添加适当的过滤条件
- 在使用 REST API 时,主动关闭已完成的操作
- 监控长时间运行的 Spark 任务,及时干预异常情况
- 考虑升级到包含此修复的 Kyuubi 版本
总结
这个问题揭示了分布式查询执行中逻辑完成与物理完成之间的差异。Kyuubi 和 Spark 的集成需要更精细的状态管理和资源控制机制。通过社区的持续改进,这类问题正在得到更好的解决,为用户提供更准确和可靠的查询体验。
登录后查看全文
热门项目推荐
相关项目推荐
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 StartedRust0213
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0137
JoyAI-EchoJoyAI-Echo,这是一个独立的、仅用于推理的版本,旨在实现分钟级多镜头音视频生成。它采用了经过蒸馏的DMD生成器、配对的跨模态记忆以及故事级别的一致性。其性能的核心在于,一个跨模态视听记忆库能够在长达五分钟的视频中保持角色外观和语音音色的一致性。同时,一个训练后处理流程将基于记忆的强化学习与分布匹配蒸馏相结合,实现了7.5倍的速度提升,显著增强了视觉质量和对齐效果。00
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
SwanLab⚡️SwanLab - an open-source, modern-design AI training tracking and visualization tool. Supports Cloud / Self-hosted use. Integrated with PyTorch / Transformers / LLaMA Factory / veRL/ Swift / Ultralytics / MMEngine / Keras etc.Python00
tiny-universe《大模型白盒子构建指南》:一个全手搓的Tiny-UniverseJupyter Notebook03
项目优选
收起
deepin linux kernel
C
32
16
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
468
461
暂无描述
Dockerfile
776
5.07 K
Ascend Extension for PyTorch
Python
756
961
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
872
2.01 K
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
696
1.4 K
昇腾LLM分布式训练框架
Python
183
230
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.1 K
1.14 K
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.04 K
271
Oohos_react_native
React Native鸿蒙化仓库
C++
361
430