From b046d9e8bf38ae1adb142adf230705f74ab06d57 Mon Sep 17 00:00:00 2001 From: Anurag Mittal Date: Thu, 19 Dec 2024 12:30:50 +0100 Subject: [PATCH] Add Prometheus metrics instrumentation for S3 ops - Instrumented `CreateBucket` and `DeleteBucket` methods to record Prometheus metrics. - Added tracking for: - Total number of S3 requests (`S3RequestsTotal`), categorized by method and status. - Duration of S3 requests (`S3RequestDuration`), categorized similarly - Ensures metrics capture both successful and failed S3 API calls. - Improves observability and debugging for S3 bucket operations. Issue: COSI-19 --- pkg/clients/s3/s3_client.go | 26 ++++++++++++++++++++++++++ pkg/constants/constants.go | 10 ++++++++-- 2 files changed, 34 insertions(+), 2 deletions(-) diff --git a/pkg/clients/s3/s3_client.go b/pkg/clients/s3/s3_client.go index 692a77c4..9b84368c 100644 --- a/pkg/clients/s3/s3_client.go +++ b/pkg/clients/s3/s3_client.go @@ -5,6 +5,7 @@ import ( "net/http" "os" "strings" + "time" "github.com/aws/aws-sdk-go-v2/aws" "github.com/aws/aws-sdk-go-v2/config" @@ -12,6 +13,8 @@ import ( "github.com/aws/aws-sdk-go-v2/service/s3" "github.com/aws/aws-sdk-go-v2/service/s3/types" "github.com/aws/smithy-go/logging" + c "github.com/scality/cosi-driver/pkg/constants" + "github.com/scality/cosi-driver/pkg/metrics" "github.com/scality/cosi-driver/pkg/util" ) @@ -65,6 +68,8 @@ var InitS3Client = func(params util.StorageClientParameters) (*S3Client, error) } func (client *S3Client) CreateBucket(ctx context.Context, bucketName string, params util.StorageClientParameters) error { + method := "CreateBucket" + start := time.Now() input := &s3.CreateBucketInput{ Bucket: &bucketName, @@ -77,12 +82,33 @@ func (client *S3Client) CreateBucket(ctx context.Context, bucketName string, par } _, err := client.S3Service.CreateBucket(ctx, input) + + duration := time.Since(start).Seconds() + status := c.StatusSuccess + if err != nil { + status = c.StatusError + } + + metrics.S3RequestsTotal.WithLabelValues(method, status).Inc() + metrics.S3RequestDuration.WithLabelValues(method, status).Observe(duration) return err } func (client *S3Client) DeleteBucket(ctx context.Context, bucketName string) error { + method := "DeleteBucket" + start := time.Now() + _, err := client.S3Service.DeleteBucket(ctx, &s3.DeleteBucketInput{ Bucket: &bucketName, }) + duration := time.Since(start).Seconds() + + status := c.StatusSuccess + if err != nil { + status = c.StatusError + } + + metrics.S3RequestsTotal.WithLabelValues(method, status).Inc() + metrics.S3RequestDuration.WithLabelValues(method, status).Observe(duration) return err } diff --git a/pkg/constants/constants.go b/pkg/constants/constants.go index 3b3c8a89..06f12350 100644 --- a/pkg/constants/constants.go +++ b/pkg/constants/constants.go @@ -13,6 +13,12 @@ const ( // Service initialization constants const ( - MetricsPath = "/metrics" - MetricsAddress = ":8080" + MetricsPath = "/metrics" // Path to expose Prometheus metrics + MetricsAddress = ":8080" // Default address to bind the metrics server +) + +// Prometheus metrics status values +const ( + StatusSuccess = "success" // Status value for successful requests + StatusError = "error" // Status value for failed requests )