Status

Please keep the discussion on the mailing list rather than commenting on the wiki (wiki discussions get unwieldy fast).

Motivation

Operational

Public Interfaces

Briefly list any new interfaces that will be introduced as part of this proposal or any existing interfaces that will be removed or changed. The purpose of this section is to concisely call out the public contract that will come along with this feature.

A public interface is any change to the following:

Command line tools and arguments

Proposed Changes

So if we have, for instance, 3 brokers id=[0..2] and are going to add fourth broker id=3, generate will create an assignment config which will redistribute replicas fairly across brokers [0..3]in the same way as those partitions were created from scratch. It will not take into consideration current replica assignment and accordingly will not try to minimize number of replica moves between brokers.

This should be improved. New output of improved rebalance ("–rebalance" command) algorithm should suite following requirements:

fairness of replica distribution - every broker will have R or R+1 replicas assigned;

minimum of reassignments - number of replica moves between brokers will be minimal;

Decommission broker command

Beside updating implementation of redistribution algorithm, new command is proposed to be added.The goal of this command is to provide a shortcut for decommissioning (removing) the broker.

Following syntax should be supported:

--decommission-broker <broker-id>

The implementation should reassign all relicas owned by specified broker to the rest of the brokersusing the above modified algorithm. Reassignment should be applied automatically without need to run –execute command.

Compatibility, Deprecation, and Migration Plan

To preserve compatibility old "–generate" command (using old algorithm) is still present. New "–rebalance" command (invoking new rebalance algorithm) is added.

What impact (if any) will there be on existing users?No impact. Old "–generate" command is preserved for compatibility.

If we are changing behavior how will we phase out the older behavior?

If we need special migration tools, describe them here.

When will we remove the existing behavior?Old "–generate" command will be removed in future releases, when decided it is no longer needed.

Rejected Alternatives

If there are alternative ways of accomplishing the same thing, what were they? The purpose of this section is to motivate why the design is the way it is and not some other way.