Skip to content

Commit

Permalink
fix: do not unregister Kong DPs metrics when Konnect integration is e…
Browse files Browse the repository at this point in the history
…nabled (#6881)
  • Loading branch information
czeslavo authored Dec 20, 2024
1 parent 28bfb94 commit 2c72b40
Show file tree
Hide file tree
Showing 13 changed files with 259 additions and 149 deletions.
12 changes: 12 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -100,6 +100,18 @@ Adding a new version? You'll need three changes:
- [0.0.5](#005)
- [0.0.4 and prior](#004-and-prior)

## Unreleased

> Release date: TBD
### Fixed

- Custom Prometheus metrics (e.g. `ingress_controller_configuration_push_count`,
`ingress_controller_configuration_push_broken_resource_count`, etc.) were not
collected properly when the Konnect integration was enabled (only Konnect-related
metrics were collected, omitting regular DP metrics). This has been fixed.
[#6881](https://github.com/Kong/kubernetes-ingress-controller/pull/6881)

## [3.4.0]

> Release date: 2024-12-18
Expand Down
2 changes: 1 addition & 1 deletion go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -169,7 +169,7 @@ require (
github.com/pkg/errors v0.9.1 // indirect
github.com/pmezard/go-difflib v1.0.1-0.20181226105442-5d4384ee4fb2 // indirect
github.com/power-devops/perfstat v0.0.0-20221212215047-62379fc7944b // indirect
github.com/prometheus/client_model v0.6.1 // indirect
github.com/prometheus/client_model v0.6.1
github.com/prometheus/procfs v0.15.1 // indirect
github.com/puzpuzpuz/xsync/v2 v2.5.1 // indirect
github.com/russross/blackfriday/v2 v2.1.0 // indirect
Expand Down
31 changes: 16 additions & 15 deletions internal/dataplane/kong_client.go
Original file line number Diff line number Diff line change
Expand Up @@ -111,9 +111,9 @@ type KongClient struct {
// information during data-plane update runtime.
diagnostic diagnostics.ClientDiagnostic

// prometheusMetrics is the client for shipping metrics information
// metricsRecorder is the client for shipping metrics information
// updates to the prometheus exporter.
prometheusMetrics *metrics.CtrlFuncMetrics
metricsRecorder metrics.Recorder

// kubernetesObjectReportLock is a mutex for thread-safety of
// kubernetes object reporting functionality.
Expand Down Expand Up @@ -201,12 +201,13 @@ func NewKongClient(
kongConfigBuilder KongConfigBuilder,
cacheStores *store.CacheStores,
fallbackConfigGenerator FallbackConfigGenerator,
metricsRecorder metrics.Recorder,
) (*KongClient, error) {
c := &KongClient{
logger: logger,
requestTimeout: timeout,
diagnostic: diagnostic,
prometheusMetrics: metrics.NewCtrlFuncMetrics(),
metricsRecorder: metricsRecorder,
cache: cacheStores,
kongConfig: kongConfig,
eventRecorder: eventRecorder,
Expand Down Expand Up @@ -454,9 +455,9 @@ func (c *KongClient) Update(ctx context.Context) error {
}
hasNewSnapshotToBeProcessed := newSnapshotHash != store.SnapshotHashEmpty
if !hasNewSnapshotToBeProcessed {
c.prometheusMetrics.RecordProcessedConfigSnapshotCacheHit()
c.metricsRecorder.RecordProcessedConfigSnapshotCacheHit()
} else {
c.prometheusMetrics.RecordProcessedConfigSnapshotCacheMiss()
c.metricsRecorder.RecordProcessedConfigSnapshotCacheMiss()
}
if hasNewSnapshotToBeProcessed {
c.logger.V(logging.DebugLevel).Info("New configuration snapshot detected", "hash", newSnapshotHash)
Expand All @@ -478,13 +479,13 @@ func (c *KongClient) Update(ctx context.Context) error {
translationDuration := time.Since(translationStart)

if failuresCount := len(parsingResult.TranslationFailures); failuresCount > 0 {
c.prometheusMetrics.RecordTranslationFailure(translationDuration)
c.prometheusMetrics.RecordTranslationBrokenResources(failuresCount)
c.metricsRecorder.RecordTranslationFailure(translationDuration)
c.metricsRecorder.RecordTranslationBrokenResources(failuresCount)
c.recordResourceFailureEvents(parsingResult.TranslationFailures, KongConfigurationTranslationFailedEventReason)
c.logger.V(logging.DebugLevel).Info("Translation failures occurred when building data-plane configuration", "count", failuresCount)
} else {
c.prometheusMetrics.RecordTranslationSuccess(translationDuration)
c.prometheusMetrics.RecordTranslationBrokenResources(0)
c.metricsRecorder.RecordTranslationSuccess(translationDuration)
c.metricsRecorder.RecordTranslationBrokenResources(0)
c.logger.V(logging.DebugLevel).Info("Successfully built data-plane configuration", "duration", translationDuration.String())
}

Expand Down Expand Up @@ -619,12 +620,12 @@ func (c *KongClient) tryRecoveringWithFallbackConfiguration(

if failuresCount := len(fallbackParsingResult.TranslationFailures); failuresCount > 0 {
c.recordResourceFailureEvents(fallbackParsingResult.TranslationFailures, FallbackKongConfigurationTranslationFailedEventReason)
c.prometheusMetrics.RecordFallbackTranslationBrokenResources(failuresCount)
c.prometheusMetrics.RecordFallbackTranslationFailure(translationDuration)
c.metricsRecorder.RecordFallbackTranslationBrokenResources(failuresCount)
c.metricsRecorder.RecordFallbackTranslationFailure(translationDuration)
c.logger.V(logging.DebugLevel).Info("Translation failures occurred when building fallback data-plane configuration", "count", failuresCount, "duration", translationDuration.String())
} else {
c.prometheusMetrics.RecordFallbackTranslationBrokenResources(0)
c.prometheusMetrics.RecordFallbackTranslationSuccess(translationDuration)
c.metricsRecorder.RecordFallbackTranslationBrokenResources(0)
c.metricsRecorder.RecordFallbackTranslationSuccess(translationDuration)
c.logger.V(logging.DebugLevel).Info("Successfully built fallback configuration from caches", "duration", translationDuration.String())
}

Expand All @@ -649,7 +650,7 @@ func (c *KongClient) generateFallbackCache(
) (s store.CacheStores, metadata fallback.GeneratedCacheMetadata, err error) {
start := time.Now()
defer func() {
c.prometheusMetrics.RecordFallbackCacheGenerationDuration(time.Since(start), err)
c.metricsRecorder.RecordFallbackCacheGenerationDuration(time.Since(start), err)
}()
if c.kongConfig.UseLastValidConfigForFallback {
return c.fallbackConfigGenerator.GenerateBackfillingBrokenObjects(
Expand Down Expand Up @@ -800,7 +801,7 @@ func (c *KongClient) sendToClient(
config,
targetContent,
customEntities,
c.prometheusMetrics,
c.metricsRecorder,
c.updateStrategyResolver,
c.configChangeDetector,
&c.diagnostic,
Expand Down
1 change: 1 addition & 0 deletions internal/dataplane/kong_client_golden_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -311,6 +311,7 @@ func runKongClientGoldenTest(t *testing.T, tc kongClientGoldenTestCase) {
p,
&cacheStores,
fallbackConfigGenerator,
mocks.MetricsRecorder{},
)
require.NoError(t, err)

Expand Down
7 changes: 7 additions & 0 deletions internal/dataplane/kong_client_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -884,6 +884,7 @@ func setupTestKongClient(
configBuilder,
&cacheStores,
newMockFallbackConfigGenerator(),
mocks.MetricsRecorder{},
)
require.NoError(t, err)
return kongClient
Expand Down Expand Up @@ -914,6 +915,7 @@ func attachKonnectConfigSynchronizer(
updateStrategyResolver,
configChangeDetector,
configStatusNotifier,
mocks.MetricsRecorder{},
)
kc.SetKonnectConfigSynchronizer(konnectConfigSynchronizer)
err := konnectConfigSynchronizer.Start(ctx)
Expand Down Expand Up @@ -1190,6 +1192,7 @@ func TestKongClient_FallbackConfiguration_SuccessfulRecovery(t *testing.T) {
configBuilder,
&originalCache,
fallbackConfigGenerator,
mocks.MetricsRecorder{},
)
require.NoError(t, err)

Expand Down Expand Up @@ -1325,6 +1328,7 @@ func TestKongClient_FallbackConfiguration_SkipsUpdateWhenInSync(t *testing.T) {
configBuilder,
&originalCache,
fallbackConfigGenerator,
mocks.MetricsRecorder{},
)
require.NoError(t, err)

Expand Down Expand Up @@ -1471,6 +1475,7 @@ func TestKongClient_FallbackConfiguration_FailedRecovery(t *testing.T) {
configBuilder,
&originalCache,
fallbackConfigGenerator,
mocks.MetricsRecorder{},
)
require.NoError(t, err)

Expand Down Expand Up @@ -1580,6 +1585,7 @@ func TestKongClient_LastValidCacheSnapshot(t *testing.T) {
configBuilder,
&originalCache,
fallbackConfigGenerator,
mocks.MetricsRecorder{},
)
require.NoError(t, err)

Expand Down Expand Up @@ -1802,6 +1808,7 @@ func TestKongClient_RecoveringFromGatewaySyncError(t *testing.T) {
configBuilder,
&originalCache,
fallbackConfigGenerator,
mocks.MetricsRecorder{},
)
require.NoError(t, err)

Expand Down
2 changes: 1 addition & 1 deletion internal/dataplane/sendconfig/sendconfig.go
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ func PerformUpdate(
config Config,
targetContent *file.Content,
customEntities CustomEntitiesByType,
promMetrics *metrics.CtrlFuncMetrics,
promMetrics metrics.Recorder,
updateStrategyResolver UpdateStrategyResolver,
configChangeDetector ConfigurationChangeDetector,
diagnostic *diagnostics.ClientDiagnostic,
Expand Down
7 changes: 4 additions & 3 deletions internal/konnect/config_synchronizer.go
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ type ConfigSynchronizer struct {
syncTicker *time.Ticker
kongConfig sendconfig.Config
konnectClient *adminapi.KonnectClient
prometheusMetrics *metrics.CtrlFuncMetrics
metricsRecorder metrics.Recorder
updateStrategyResolver sendconfig.UpdateStrategyResolver
configChangeDetector sendconfig.ConfigurationChangeDetector
configStatusNotifier clients.ConfigStatusNotifier
Expand All @@ -48,13 +48,14 @@ func NewConfigSynchronizer(
updateStrategyResolver sendconfig.UpdateStrategyResolver,
configChangeDetector sendconfig.ConfigurationChangeDetector,
configStatusNotifier clients.ConfigStatusNotifier,
metricsRecorder metrics.Recorder,
) *ConfigSynchronizer {
return &ConfigSynchronizer{
logger: logger,
syncTicker: time.NewTicker(configUploadPeriod),
kongConfig: kongConfig,
konnectClient: konnectClient,
prometheusMetrics: metrics.NewCtrlFuncMetrics(),
metricsRecorder: metricsRecorder,
updateStrategyResolver: updateStrategyResolver,
configChangeDetector: configChangeDetector,
configStatusNotifier: configStatusNotifier,
Expand Down Expand Up @@ -134,7 +135,7 @@ func (s *ConfigSynchronizer) uploadConfig(ctx context.Context, client *adminapi.
targetContent,
// Konnect client does not upload custom entities.
sendconfig.CustomEntitiesByType{},
s.prometheusMetrics,
s.metricsRecorder,
s.updateStrategyResolver,
s.configChangeDetector,
nil,
Expand Down
3 changes: 1 addition & 2 deletions internal/konnect/config_synchronizer_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,6 @@ import (
"github.com/kong/kubernetes-ingress-controller/v3/internal/adminapi"
"github.com/kong/kubernetes-ingress-controller/v3/internal/clients"
"github.com/kong/kubernetes-ingress-controller/v3/internal/dataplane/sendconfig"
"github.com/kong/kubernetes-ingress-controller/v3/internal/metrics"
"github.com/kong/kubernetes-ingress-controller/v3/test/mocks"
)

Expand Down Expand Up @@ -69,7 +68,7 @@ func TestConfigSynchronizer_RunKonnectUpdateServer(t *testing.T) {
logger: logr.Discard(),
syncTicker: time.NewTicker(sendConfigPeriod),
konnectClient: testKonnectClient,
prometheusMetrics: metrics.NewCtrlFuncMetrics(),
metricsRecorder: mocks.MetricsRecorder{},
updateStrategyResolver: resolver,
configChangeDetector: sendconfig.NewDefaultConfigurationChangeDetector(log),
configStatusNotifier: clients.NoOpConfigStatusNotifier{},
Expand Down
4 changes: 4 additions & 0 deletions internal/manager/run.go
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ import (
"github.com/kong/kubernetes-ingress-controller/v3/internal/manager/metadata"
"github.com/kong/kubernetes-ingress-controller/v3/internal/manager/telemetry"
"github.com/kong/kubernetes-ingress-controller/v3/internal/manager/utils/kongconfig"
"github.com/kong/kubernetes-ingress-controller/v3/internal/metrics"
"github.com/kong/kubernetes-ingress-controller/v3/internal/store"
"github.com/kong/kubernetes-ingress-controller/v3/internal/util"
"github.com/kong/kubernetes-ingress-controller/v3/internal/util/kubernetes/object/status"
Expand Down Expand Up @@ -200,6 +201,7 @@ func Run(
configurationChangeDetector := sendconfig.NewDefaultConfigurationChangeDetector(logger)
kongConfigFetcher := configfetcher.NewDefaultKongLastGoodConfigFetcher(translatorFeatureFlags.FillIDs, c.KongWorkspace)
fallbackConfigGenerator := fallback.NewGenerator(fallback.NewDefaultCacheGraphProvider(), logger)
metricsRecorder := metrics.NewGlobalCtrlRuntimeMetricsRecorder()
dataplaneClient, err := dataplane.NewKongClient(
logger,
time.Duration(c.ProxyTimeoutSeconds*float32(time.Second)),
Expand All @@ -214,6 +216,7 @@ func Run(
configTranslator,
&cache,
fallbackConfigGenerator,
metricsRecorder,
)
if err != nil {
return fmt.Errorf("failed to initialize kong data-plane client: %w", err)
Expand Down Expand Up @@ -293,6 +296,7 @@ func Run(
clientsManager,
updateStrategyResolver,
configStatusNotifier,
metricsRecorder,
)
if err != nil {
setupLog.Error(err, "Failed to setup Konnect configuration synchronizer with manager, skipping")
Expand Down
3 changes: 3 additions & 0 deletions internal/manager/setup.go
Original file line number Diff line number Diff line change
Expand Up @@ -39,6 +39,7 @@ import (
"github.com/kong/kubernetes-ingress-controller/v3/internal/license"
"github.com/kong/kubernetes-ingress-controller/v3/internal/logging"
"github.com/kong/kubernetes-ingress-controller/v3/internal/manager/scheme"
"github.com/kong/kubernetes-ingress-controller/v3/internal/metrics"
"github.com/kong/kubernetes-ingress-controller/v3/internal/store"
"github.com/kong/kubernetes-ingress-controller/v3/internal/util/kubernetes/object/status"
)
Expand Down Expand Up @@ -495,6 +496,7 @@ func setupKonnectConfigSynchronizer(
clientsProvider clients.AdminAPIClientsProvider,
updateStrategyResolver sendconfig.UpdateStrategyResolver,
configStatusNotifier clients.ConfigStatusNotifier,
metricsRecorder metrics.Recorder,
) (*konnect.ConfigSynchronizer, error) {
logger := ctrl.LoggerFrom(ctx).WithName("konnect-config-synchronizer")
s := konnect.NewConfigSynchronizer(
Expand All @@ -505,6 +507,7 @@ func setupKonnectConfigSynchronizer(
updateStrategyResolver,
sendconfig.NewDefaultConfigurationChangeDetector(logger),
configStatusNotifier,
metricsRecorder,
)
err := mgr.Add(s)
if err != nil {
Expand Down
Loading

0 comments on commit 2c72b40

Please sign in to comment.