Skip to content

Commit

Permalink
feat: --konnect-disable-consumer-sync flag (#6313)
Browse files Browse the repository at this point in the history
* feat: --konnect-disable-consumer-sync flag

Signed-off-by: Mattia Lavacca <[email protected]>

* address review comments

Signed-off-by: Mattia Lavacca <[email protected]>

---------

Signed-off-by: Mattia Lavacca <[email protected]>
  • Loading branch information
mlavacca authored Jul 16, 2024
1 parent ffd9e9e commit 313234c
Show file tree
Hide file tree
Showing 7 changed files with 23 additions and 5 deletions.
3 changes: 3 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -99,6 +99,9 @@ Adding a new version? You'll need three changes:

- `KongCustomEntity` is now supported by the `FallbackConfiguration` feature.
[#6286](https://github.com/Kong/kubernetes-ingress-controller/pull/6286)
- It is now possible to disable synchronization of consumers to Konnect through the
flag `--konnect-disable-consumers-sync`.
[#6313](https://github.com/Kong/kubernetes-ingress-controller/pull/6313)

### Fixed

Expand Down
1 change: 1 addition & 0 deletions docs/cli-arguments.md
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,7 @@
| `--kong-workspace` | `string` | Kong Enterprise workspace to configure. Leave this empty if not using Kong workspaces. | |
| `--konnect-address` | `string` | Base address of Konnect API. | `https://us.kic.api.konghq.com` |
| `--konnect-control-plane-id` | `string` | An ID of a control plane that is to be synchronized with data plane configuration. | |
| `--konnect-disable-consumers-sync` | `bool` | Disable synchronization of consumers with Konnect. | `false` |
| `--konnect-initial-license-polling-period` | `duration` | Polling period to be used before the first license is retrieved. | `1m0s` |
| `--konnect-license-polling-period` | `duration` | Polling period to be used after the first license is retrieved. | `12h0m0s` |
| `--konnect-licensing-enabled` | `bool` | Retrieve licenses from Konnect if available. Overrides licenses provided via the environment. | `false` |
Expand Down
12 changes: 9 additions & 3 deletions internal/adminapi/client.go
Original file line number Diff line number Diff line change
Expand Up @@ -52,26 +52,32 @@ func NewTestClient(address string) (*Client, error) {

type KonnectClient struct {
Client
backoffStrategy UpdateBackoffStrategy
consumersSyncDisabled bool
backoffStrategy UpdateBackoffStrategy
}

// NewKonnectClient creates an Admin API client that is to be used with a Konnect Control Plane Admin API.
func NewKonnectClient(c *kong.Client, controlPlane string) *KonnectClient {
func NewKonnectClient(c *kong.Client, controlPlane string, consumersSyncDisabled bool) *KonnectClient {
return &KonnectClient{
Client: Client{
adminAPIClient: c,
isKonnect: true,
konnectControlPlane: controlPlane,
pluginSchemaStore: util.NewPluginSchemaStore(c),
},
backoffStrategy: NewKonnectBackoffStrategy(clock.System{}),
backoffStrategy: NewKonnectBackoffStrategy(clock.System{}),
consumersSyncDisabled: consumersSyncDisabled,
}
}

func (c *KonnectClient) BackoffStrategy() UpdateBackoffStrategy {
return c.backoffStrategy
}

func (c *KonnectClient) ConsumersSyncDisabled() bool {
return c.consumersSyncDisabled
}

// AdminAPIClient returns an underlying go-kong's Admin API client.
func (c *Client) AdminAPIClient() *kong.Client {
return c.adminAPIClient
Expand Down
3 changes: 2 additions & 1 deletion internal/adminapi/konnect.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@ type KonnectConfig struct {
LicenseSynchronizationEnabled bool
InitialLicensePollingPeriod time.Duration
LicensePollingPeriod time.Duration
ConsumersSyncDisabled bool
}

func NewKongClientForKonnectControlPlane(c KonnectConfig) (*KonnectClient, error) {
Expand Down Expand Up @@ -59,7 +60,7 @@ func NewKongClientForKonnectControlPlane(c KonnectConfig) (*KonnectClient, error
if err != nil {
return nil, err
}
return NewKonnectClient(client, c.ControlPlaneID), nil
return NewKonnectClient(client, c.ControlPlaneID, c.ConsumersSyncDisabled), nil
}

// EnsureKonnectConnection ensures that the client is able to connect to Konnect.
Expand Down
6 changes: 6 additions & 0 deletions internal/dataplane/kong_client.go
Original file line number Diff line number Diff line change
Expand Up @@ -740,6 +740,12 @@ func (c *KongClient) maybeSendOutToKonnectClient(
return nil
}

// In case users have many consumers, konnect sync can be very slow and cause dataplane sync issues.
// For this reason, if the --disable-consumers-sync flag is set, we do not send consumers to Konnect.
if konnectClient.ConsumersSyncDisabled() {
s.Consumers = nil
}

if _, err := c.sendToClient(ctx, konnectClient, s, config, isFallback); err != nil {
// In case of an error, we only log it since we don't want the Konnect to affect the basic functionality
// of the controller.
Expand Down
2 changes: 1 addition & 1 deletion internal/dataplane/kong_client_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -961,7 +961,7 @@ func mustSampleKonnectClient(t *testing.T) *adminapi.KonnectClient {
require.NoError(t, err)

rgID := uuid.NewString()
return adminapi.NewKonnectClient(c, rgID)
return adminapi.NewKonnectClient(c, rgID, false)
}

func mapClientsToUrls(clients *mockGatewayClientsProvider) []string {
Expand Down
1 change: 1 addition & 0 deletions internal/manager/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -313,6 +313,7 @@ func (c *Config) FlagSet() *pflag.FlagSet {
flagSet.StringVar(&c.Konnect.TLSClient.Key, "konnect-tls-client-key", "", "Konnect TLS client key.")
flagSet.StringVar(&c.Konnect.TLSClient.KeyFile, "konnect-tls-client-key-file", "", "Konnect TLS client key file path.")
flagSet.DurationVar(&c.Konnect.RefreshNodePeriod, "konnect-refresh-node-period", konnect.DefaultRefreshNodePeriod, "Period of uploading status of KIC and controlled Kong instances.")
flagSet.BoolVar(&c.Konnect.ConsumersSyncDisabled, "konnect-disable-consumers-sync", false, "Disable synchronization of consumers with Konnect.")

// Deprecated flags.
flagSet.StringVar(&c.Konnect.ControlPlaneID, "konnect-runtime-group-id", "", "Use --konnect-control-plane-id instead.")
Expand Down

0 comments on commit 313234c

Please sign in to comment.