监控反压
如果你看到一个 task 发生 反压警告(例如: ),意味着它生产数据的速率比下游 task 消费数据的速率要快。 在工作流中数据记录是从上游向下游流动的(例如:从 Source 到 Sink)。反压沿着相反的方向传播,沿着数据流向上游传播。
以一个简单的 Source -> Sink
job 为例。如果看到 Source
发生了警告,意味着 Sink
消费数据的速率比 生产数据的速率要慢。 Sink
正在向上游的 Source
算子产生反压。
Task(SubTask)的每个并行实例都可以用三个一组的指标评价:
backPressureTimeMsPerSecond
,subtask 被反压的时间busyTimeMsPerSecond
,subtask 实际工作时间 在任何时间点,这三个指标相加都约等于1000ms
。
在内部,反压根据输出 buffers 的可用性来进行判断的。 如果一个 task 没有可用的输出 buffers,那么这个 task 就被认定是在被反压。 相反,如果有可用的输入,则可认定为闲置,
WebUI 集合了所有 subTasks 的反压和繁忙指标的最大值,并在 JobGraph 中将集合的值进行显示。除了显示原始的数值,tasks 也用颜色进行了标记,使检查更加容易。
在 Job Overview 旁的 Back Pressure 选项卡中,你可以找到更多细节指标。
如果你看到 subtasks 的状态为 OK 表示没有反压。HIGH 表示这个 subtask 被反压。状态用如下定义:
- OK: 0% <= 反压比例 <= 10%
- HIGH: 50% < 反压比例 <= 100%