-
Notifications
You must be signed in to change notification settings - Fork 1.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Sarama roadmap #1732
Comments
@d1egoaz that sounds good I wonder if it’s worth having some Slack channel or https://gitter.im/home room for Sarama? |
I am available and looking forward to i. I am fine with zoom or slack.
Thanks,
Varun
…On Tue, Jun 23, 2020 at 2:39 PM Dominic Evans ***@***.***> wrote:
@d1egoaz <https://github.com/d1egoaz> that sounds good
I wonder if it’s worth having some Slack channel or https://gitter.im/home
room for Sarama?
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#1732 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AAJZPZWHJMKULQWBVJJ6XSTRYEAHLANCNFSM4OF7BMCA>
.
|
A few major things that come to mind which I'd like to propose that we could discuss about having in-place before releasing a major v2 version are: Make a /v2 directory on default branchFollowing https://blog.golang.org/v2-go-modules we'd
Proper use and adherence to ApiVersion{Request,Response}Historically Sarama has tied it's protocol usage to the Move Kafka protocol code and packet encoder+decoder etc. out into a separate packageI think it would be useful to have a general purpose Kafka protocol encoder+decode available for other Go-based projects to consume, so I think we should move this out to it's own dedicated package and make the encoder+decoder visibile outside the package As part of that work I wonder if we'd want to revisit the params and return values that Sarama itself uses. In some places we accept and return the raw protocol structs unlike the Java client which has its own types for those. Support saving protocol read+write to .pcap file?Can we provide a debug capability to write the client wire protocol exchange to one or more .pcap style files? When users raise bugs/issues it would often be useful to have a dump of the protocol exchange that their client(s) had with the various brokers in the cluster. However, it can be problematic getting users to capture these themselves with wireshark et al. when they're typically using TLS between the client and the brokers. Could we instead provide an option in Sarama to write the TCPConn data to a file — perhaps per broker? Revisit current use of goroutines and channels
Do we think it would be feasible to provide a useful Producer and Consumer API without doing any lifecycle management internally? Instead we'd provide entirely sync functions that the caller would be expected to drive. We'd bridge the gap by providing more comprehensive examples. MetricsIs rcrowley/go-metrics still our preferred option here? Should we be using prometheus/client_golang internally instead? Can we do a user survey to determine how/if users are collecting their metrics from their clients? |
I wonder if @eapache would be interested in joining? I know he's been very busy with other projects for the last year or so, but seeing as he was the one who originally started Sarama off, I imagine he would have some valuable insight about the current design choices and direction he would have liked it to be taken. If you wanted to involve some major Sarama users then I'd perhaps also suggest inviting @KJTsanaktsidis @sladkoff @lizthegrey to provide input on their usage of Sarama and what they'd like to see from a v2 |
I think what you've described makes sense @dnwe. I'm pretty biased against go-metrics as it's been a source of memory leaks in the past. Would love see if we could provide metrics using prometheus' client_golang. I'd also love to have a stricter linting across the project to match current standards. |
Metrics and linting can be easy wins out of the gate. I might actually have a branch on linting, let's see if I can finish that and push. For Metrics, I agree that it has been a point of concern. We can look at Prometheus and open census(open telemetry or whatever it is called now). Do we want to add tracing support also, or metrics are fine? |
👋 I unfortunately haven't been following the evolution of this project at all in the last year or so, and I'm quite busy for the next few weeks with another project, but I'm still interested in chatting and providing my fully un-informed opinions :) I want to mention https://github.com/Shopify/sarama/wiki/Ideas-that-will-break-backwards-compatibility as a nice long collection of things we should fix or think about if we decide to do a breaking v2. Back when I was maintaining Sarama I dumped a lot of random ideas there. Off the top of my head all of the points in that list are still valid/important.
That seems like a nice thing to bake in everywhere if that protocol is now available in all of Sarama's supported Kafka versions. It had only just been introduced last time I was paying any attention, so we still needed to support older brokers at that point.
Isn't this just creating and manually sending request objects to brokers, which you can already do? I think I'd support splitting out the basics into a separate package from the producer/consumer/etc, but in my mind the complex parallelism/lifecycle management is where most of the actual value in Sarama lies. I think Bryan's principle is meant to apply to more low-level packages, not to high-level client libraries that have to do state management anyway.
Yeah, sorry, I merged a PR to add go-metrics support without thinking about it too hard and without any use case for it myself. If we have a better alternative, let's do that. |
One thing that prevented me to use Sarama as a basis for some tools is the lack of support for transactions. The asynchronous internals of Kafka and the way retries are handled does make this difficult to implement.
I think tracing would be nice. Metric does not replace tracing. |
I'm keen to be involved in talking about Sarama's roadmap, and I'd participate in a gitter/slack too. I'm going to talk to a few people inside my company about what our strategy is with Kafka/Go over the next few days, so I'll be back to bounce some ideas around soon hopefully :) |
FYI - I have a lint/vet fix branch on top of V2 that I will be pushing in next few days. As far as messaging go, should we start a slack channel(may be in gopher slack)?? |
I got #sarama channel created on Gophers Slack. |
do we need an invitation? |
I've been working on #1730 to allow for third-party components to hook into the consumer/producer for custom monitoring, logging, tracing, etc. |
Removing In my case, to reduce cluttering everything up, I opted to go for a codec-style approach where I have extraneous objects and funcs solely for the purpose of taking in objects that can |
Thank you for taking the time to raise this issue. However, it has not had any activity on it in the past 90 days and will be closed in 30 days if no updates occur. |
Hi folks, what's the status of v2 roadmap and planning? I'm very interested on having "Move Kafka protocol code and packet encoder+decoder etc. out into a separate package" point done asap, so wondering how can I help to make this happen. What about allowing #1967 to happen as first step? |
I wonder if we should cut a release of 1.30.0 from the current state of main, push a copy of that to a @bai thoughts? |
We used to have v2 branch that was not visible, advertised, or otherwise maintained, that eventually turned into abandonware. I wonder if we could create v2 in the current main tree as a first-class citizen and require some sort of parity (passing tests, compatible PRs, etc)? Re cutting 1.30.0: I'd like to include #2034 into it if that's ok. |
I know you didn't ask me, so I hope you don't mind. IMHO this is the most appropriate and idiomatic way of handling this. |
Hey friends @bai @dnwe @varun06 @mimaison @edoardocomar @FrancoisPoinsot @skidder
I wonder if we can meet any time in the next weeks so we can talk/decide more about Sarama present and future --> Roadmap.
Would you prefer more an asynchronous communication via github issues? if yes, I'd create some issues to start some conversations.
Am I missing contributors on the above list?
The text was updated successfully, but these errors were encountered: