Details
-
Improvement
-
Status: Closed
-
Major
-
Resolution: Duplicate
-
None
-
None
Description
Today our task placement may still generate sub-optimal assignment regarding load balance. One reason is that it does not account for sub-topologies. For example say you have an aggregation following from a repartition topic, then you will end up with two sub-topologies where the first one is very light and the second one is computational heavy with state stores, however when we consider their tasks we treat them equally so in the worst case one client can get X number of tasks from first sub-topology and be very idle while the other getting X number of tasks from the second sub-topology and busy to death.
One strawman approach to make this better is try to achieve balance across sub-topologies: i.e. each client trying to get similar amount of tasks within a sub-topology. However there are some more considerations to include (as mentioned in the sub-taks).
Attachments
Issue Links
- is a parent of
-
KAFKA-5578 Streams Task Assignor should consider the staleness of state directories when allocating tasks
- Closed
- Is contained by
-
KAFKA-6145 Warm up new KS instances before migrating tasks - potentially a two phase rebalance
- Resolved
- links to