From 5d4a8bd9f45bbc1d51c95a82eb3e2f6740875d31 Mon Sep 17 00:00:00 2001 From: reus Date: Tue, 30 Jul 2024 16:19:00 +0800 Subject: [PATCH] fileservice: add active reader metrics to object storage --- pkg/fileservice/object_storage_metrics.go | 53 ++++++++++++------- .../v2/dashboard/grafana_dashboard_fs.go | 4 ++ 2 files changed, 37 insertions(+), 20 deletions(-) diff --git a/pkg/fileservice/object_storage_metrics.go b/pkg/fileservice/object_storage_metrics.go index 8e89b29f612fb..dfb5dab12d4fd 100644 --- a/pkg/fileservice/object_storage_metrics.go +++ b/pkg/fileservice/object_storage_metrics.go @@ -27,12 +27,13 @@ import ( type objectStorageMetrics struct { upstream ObjectStorage - numDelete prometheus.Gauge - numExists prometheus.Gauge - numList prometheus.Gauge - numRead prometheus.Gauge - numStat prometheus.Gauge - numWrite prometheus.Gauge + numDelete prometheus.Gauge + numExists prometheus.Gauge + numList prometheus.Gauge + numRead prometheus.Gauge + numActiveRead prometheus.Gauge + numStat prometheus.Gauge + numWrite prometheus.Gauge } func newObjectStorageMetrics( @@ -42,43 +43,55 @@ func newObjectStorageMetrics( return &objectStorageMetrics{ upstream: upstream, - numRead: metric.FSObjectStorageOperations.WithLabelValues(name, "read"), - numWrite: metric.FSObjectStorageOperations.WithLabelValues(name, "write"), - numDelete: metric.FSObjectStorageOperations.WithLabelValues(name, "delete"), - numList: metric.FSObjectStorageOperations.WithLabelValues(name, "list"), - numExists: metric.FSObjectStorageOperations.WithLabelValues(name, "exists"), - numStat: metric.FSObjectStorageOperations.WithLabelValues(name, "stat"), + numRead: metric.FSObjectStorageOperations.WithLabelValues(name, "read"), + numActiveRead: metric.FSObjectStorageOperations.WithLabelValues(name, "active-read"), + numWrite: metric.FSObjectStorageOperations.WithLabelValues(name, "write"), + numDelete: metric.FSObjectStorageOperations.WithLabelValues(name, "delete"), + numList: metric.FSObjectStorageOperations.WithLabelValues(name, "list"), + numExists: metric.FSObjectStorageOperations.WithLabelValues(name, "exists"), + numStat: metric.FSObjectStorageOperations.WithLabelValues(name, "stat"), } } var _ ObjectStorage = new(objectStorageMetrics) func (o *objectStorageMetrics) Delete(ctx context.Context, keys ...string) (err error) { - o.numDelete.Add(1) + o.numDelete.Inc() return o.upstream.Delete(ctx, keys...) } func (o *objectStorageMetrics) Exists(ctx context.Context, key string) (bool, error) { - o.numExists.Add(1) + o.numExists.Inc() return o.upstream.Exists(ctx, key) } func (o *objectStorageMetrics) List(ctx context.Context, prefix string, fn func(isPrefix bool, key string, size int64) (bool, error)) (err error) { - o.numList.Add(1) + o.numList.Inc() return o.upstream.List(ctx, prefix, fn) } -func (o *objectStorageMetrics) Read(ctx context.Context, key string, min *int64, max *int64) (r io.ReadCloser, err error) { - o.numRead.Add(1) - return o.upstream.Read(ctx, key, min, max) +func (o *objectStorageMetrics) Read(ctx context.Context, key string, min *int64, max *int64) (io.ReadCloser, error) { + o.numRead.Inc() + o.numActiveRead.Inc() + r, err := o.upstream.Read(ctx, key, min, max) + if err != nil { + return nil, err + } + return &readCloser{ + r: r, + closeFunc: func() error { + o.numActiveRead.Dec() + return r.Close() + }, + }, nil } func (o *objectStorageMetrics) Stat(ctx context.Context, key string) (size int64, err error) { - o.numStat.Add(1) + o.numStat.Inc() return o.upstream.Stat(ctx, key) } func (o *objectStorageMetrics) Write(ctx context.Context, key string, r io.Reader, size int64, expire *time.Time) (err error) { - o.numWrite.Add(1) + o.numWrite.Inc() return o.upstream.Write(ctx, key, r, size, expire) } diff --git a/pkg/util/metric/v2/dashboard/grafana_dashboard_fs.go b/pkg/util/metric/v2/dashboard/grafana_dashboard_fs.go index 6d1ceecbb018f..9ac0ac9aaa3b0 100644 --- a/pkg/util/metric/v2/dashboard/grafana_dashboard_fs.go +++ b/pkg/util/metric/v2/dashboard/grafana_dashboard_fs.go @@ -228,6 +228,7 @@ func (c *DashboardCreator) initFSObjectStorageRow() dashboard.Option { 3, []string{ c.getMetricWithFilter("mo_fs_object_storage_operations", `name="s3",op="read"`), + c.getMetricWithFilter("mo_fs_object_storage_operations", `name="s3",op="active-read"`), c.getMetricWithFilter("mo_fs_object_storage_operations", `name="s3",op="write"`), c.getMetricWithFilter("mo_fs_object_storage_operations", `name="s3",op="delete"`), c.getMetricWithFilter("mo_fs_object_storage_operations", `name="s3",op="list"`), @@ -236,6 +237,7 @@ func (c *DashboardCreator) initFSObjectStorageRow() dashboard.Option { }, []string{ "read", + "active-read", "write", "delete", "list", @@ -249,6 +251,7 @@ func (c *DashboardCreator) initFSObjectStorageRow() dashboard.Option { 3, []string{ `rate(` + c.getMetricWithFilter("mo_fs_object_storage_operations", `name="s3",op="read"`) + `[$interval])`, + `rate(` + c.getMetricWithFilter("mo_fs_object_storage_operations", `name="s3",op="active-read"`) + `[$interval])`, `rate(` + c.getMetricWithFilter("mo_fs_object_storage_operations", `name="s3",op="write"`) + `[$interval])`, `rate(` + c.getMetricWithFilter("mo_fs_object_storage_operations", `name="s3",op="delete"`) + `[$interval])`, `rate(` + c.getMetricWithFilter("mo_fs_object_storage_operations", `name="s3",op="list"`) + `[$interval])`, @@ -257,6 +260,7 @@ func (c *DashboardCreator) initFSObjectStorageRow() dashboard.Option { }, []string{ "read", + "active-read", "write", "delete", "list",