-
Notifications
You must be signed in to change notification settings - Fork 1.8k
Ideas that will break backwards compatibility
Evan Huus edited this page Dec 11, 2015
·
25 revisions
The following ideas cannot be implemented in v1, because they would break backwards compatibility. Listing them here to be revisited when we decide to do a v2. (Just because they're here doesn't necessarily mean they'll be in v2 though).
-
Client.Replicas
should return[]*Broker
, it is safe to do now we have lazy connections. Or is it enough to just addClient.Broker(int32) *Broker
? - Remove
Encoder
interface. It makes the API more complicated to use, and we cannot "stream" the content anyway: we need to send a CRC32 to the broker first which requires buffering the entire value in memory. - Move Request/Response objects to
protocol
subpackage, and export Encode and Decode methods. Maybe also move producer, consumer, clients to their own (sub)packages so that e.g. a producer binary doesn't have to pull in all the consumer code. -
ConsumerMetadataResponse
has some deprecated fields (replaced by a single*Broker
) which can be removed. - Make backoff values
[]time.Duration
so that exponential and other backoff patterns can be easily specified using e.g. https://godoc.org/github.com/eapache/go-resiliency/retrier#ConstantBackoff and friends - Use logrus for structured logging?
- The
kafka-console-partitionconsumer
tool can be removed, it is superseded bykafka-console-consumer
. - Go lint wants
Id
to beID
everywhere, e.g.GroupId
should beGroupID
in several protocol fields