Skip to content

Commit

Permalink
feat: allow retry on init failure
Browse files Browse the repository at this point in the history
  • Loading branch information
Scandiravian committed Aug 30, 2022
1 parent 5a5c788 commit ec81468
Show file tree
Hide file tree
Showing 3 changed files with 23 additions and 7 deletions.
3 changes: 3 additions & 0 deletions charts/kminion/values.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -171,6 +171,9 @@ kminion:
# username: ""
# password: ""
# realm: ""
# # Whether to retry the initial test connection to Kafka. False will exit with code 1 on error,
# # while true will retry until success.
# retryInitConnection: false
#
# minion:
# consumerGroups:
Expand Down
2 changes: 2 additions & 0 deletions kafka/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@ type Config struct {

TLS TLSConfig `koanf:"tls"`
SASL SASLConfig `koanf:"sasl"`

RetryInitConnection bool `koanf:"retryInitConnection"`
}

func (c *Config) SetDefaults() {
Expand Down
25 changes: 18 additions & 7 deletions kafka/service.go
Original file line number Diff line number Diff line change
Expand Up @@ -43,11 +43,19 @@ func (s *Service) CreateAndTestClient(ctx context.Context, l *zap.Logger, opts [
}

// Test connection
connectCtx, cancel := context.WithTimeout(ctx, 15*time.Second)
defer cancel()
err = s.testConnection(client, connectCtx)
if err != nil {
return nil, fmt.Errorf("failed to test connectivity to Kafka cluster %w", err)
for {
err = s.testConnection(client, ctx)
if err == nil {
break
}
returnErr := fmt.Errorf("failed to test connectivity to Kafka cluster %w", err)

if !s.cfg.RetryInitConnection {
return nil, returnErr
}

logger.Error(fmt.Sprintf("%s, retrying in 5 seconds", returnErr.Error()))
time.Sleep(time.Second * 5)
}

return client, nil
Expand All @@ -61,17 +69,20 @@ func (s *Service) Brokers() []string {
// testConnection tries to fetch Broker metadata and prints some information if connection succeeds. An error will be
// returned if connecting fails.
func (s *Service) testConnection(client *kgo.Client, ctx context.Context) error {
connectCtx, cancel := context.WithTimeout(ctx, 15*time.Second)
defer cancel()

req := kmsg.MetadataRequest{
Topics: nil,
}
res, err := req.RequestWith(ctx, client)
res, err := req.RequestWith(connectCtx, client)
if err != nil {
return fmt.Errorf("failed to request metadata: %w", err)
}

// Request versions in order to guess Kafka Cluster version
versionsReq := kmsg.NewApiVersionsRequest()
versionsRes, err := versionsReq.RequestWith(ctx, client)
versionsRes, err := versionsReq.RequestWith(connectCtx, client)
if err != nil {
return fmt.Errorf("failed to request api versions: %w", err)
}
Expand Down

0 comments on commit ec81468

Please sign in to comment.