我注意到在我的工作中,吞吐量(报告的记录数/秒)在“分组”步骤之后显着减慢。当该工作流步骤执行时,我看到某些实例的 CPU 利用率约为 30%,而有些实例似乎处于空闲状态。
是数据流问题还是我应该以某种方式指示工作流增加此步骤的并行性?
谢谢,G
我注意到在我的工作中,吞吐量(报告的记录数/秒)在“分组”步骤之后显着减慢。当该工作流步骤执行时,我看到某些实例的 CPU 利用率约为 30%,而有些实例似乎处于空闲状态。
是数据流问题还是我应该以某种方式指示工作流增加此步骤的并行性?
谢谢,G
如果不了解您的管道正在做什么的更多细节,就很难确定发生了什么。
一般来说,吞吐量(记录数/秒)取决于几个因素,例如
一般来说,GroupByKey 会构造一个更大的记录,该记录由一个键和具有该键的所有值组成;即输入是 KV<K,V> 的集合,输出是 KV<K, Iterable<V>> 的集合
因此,通常我希望 GroupByKey 输出的记录比输入记录大得多。由于记录较大,因此处理时间较长,因此记录/秒会趋于减少。
在 Dataflow 的 Alpha 版本中,CPU 利用率低并不意外。目前,Dataflow 并未充分利用所有 VM 内核来处理工作。许多性能改进正在改善这一点。
Dataflow 目前提供了两个旋钮,用于通过标志调整并行度
--numWorkers=<integer>
--workerMachineType=<Name of GCE VM Machine Type>
--numWorkers 允许您增加或减少用于并行处理数据的工作人员数量。一般来说,增加工作人员的数量可以并行处理更多的数据。
使用 --workerMachineType 您可以选择具有更多或更少 CPU 或 RAM 的机器。
如果您发现 VM 的 CPU 未得到充分利用,您可以选择 CPU 较少的机器(默认情况下,Dataflow 每个 VM 使用 4 个 CPU)。如果您减少每台机器的 CPU,但增加 numWorkers 以使 CPU 总数大致相同,则您可能能够在不增加工作成本的情况下增加并行度。
目前,Dataflow 仅提供这些非常粗略的旋钮来控制全局级别(而不是每个阶段级别)的并行量。这在未来可能会改变。但是,总的来说,我们的目标是自动为您调整并行度,因此您不必这样做。
低吞吐量也可能是“热键”或非常频繁出现的键的结果。这将导致由单个工作线程上的单个核心处理的一些非常大的集合。
这是谷歌关于热键以及如何处理它们的官方文档。根据我的经验,使用Combine.PerKeyWithHotKeyFanout有选择地应用扇出因子已经产生了很好的结果。