requesting

command
v0.3.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 27, 2023 License: BSD-3-Clause Imports: 8 Imported by: 0

README

Message requests

With franz-go you can directly construct message requests and send them to your Kafka cluster. There are three options how you can issue requests:

  • Using the broker's Request method
  • Using the client's Request method
  • Using the message's RequestWith method

Broker Requests

Interface:

func (b *Broker) Request(ctx context.Context, req kmsg.Request) (kmsg.Response, error)

Reference: https://pkg.go.dev/github.com/YenchangChan/franz-go/pkg/kgo#Broker.Request

Use this method only if you need to send requests to a specific broker. The actual response type has to be asserted. Requests sent using this method are not retried.

Client Requests

func (cl *Client) Request(ctx context.Context, req kmsg.Request) (kmsg.Response, error)

Reference: https://pkg.go.dev/github.com/YenchangChan/franz-go/pkg/kgo#Client.Request

The client provides a lot functionality making sure that your message request will be sent in the most efficient manner to the right set of brokers. Additionally it will retry your requests if needed. The actual response type has to be asserted.

Message Requests

// Example for ListOffsetsRequest
func (v *ListOffsetsRequest) RequestWith(ctx context.Context, r Requestor) (*ListOffsetsResponse, error)

Reference: https://pkg.go.dev/github.com/YenchangChan/franz-go/pkg/kmsg

Each request message in the kmsg package has it's own RequestWith method which accepts a context and an interface which Client already fulfills. This method uses the client's Request method with the advantage that you don't need to assert the actual response type.

Most commonly you want to use this method to send requests to Kafka.

Documentation

The Go Gopher

There is no documentation for this package.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL