Skip to content

Commit

Permalink
add some metrics for monitoring compactor (#2548)
Browse files Browse the repository at this point in the history
  • Loading branch information
sandeepsukhani authored Aug 27, 2020
1 parent 4f6a4c2 commit 1bba2a8
Show file tree
Hide file tree
Showing 3 changed files with 54 additions and 4 deletions.
2 changes: 1 addition & 1 deletion pkg/loki/modules.go
Original file line number Diff line number Diff line change
Expand Up @@ -436,7 +436,7 @@ func (t *Loki) initMemberlistKV() (services.Service, error) {

func (t *Loki) initCompactor() (services.Service, error) {
var err error
t.compactor, err = compactor.NewCompactor(t.cfg.CompactorConfig, t.cfg.StorageConfig.Config)
t.compactor, err = compactor.NewCompactor(t.cfg.CompactorConfig, t.cfg.StorageConfig.Config, prometheus.DefaultRegisterer)
if err != nil {
return nil, err
}
Expand Down
23 changes: 20 additions & 3 deletions pkg/storage/stores/shipper/compactor/compactor.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ import (
pkg_util "github.com/cortexproject/cortex/pkg/util"
"github.com/cortexproject/cortex/pkg/util/services"
"github.com/go-kit/kit/log/level"
"github.com/prometheus/client_golang/prometheus"

"github.com/grafana/loki/pkg/storage/stores/shipper"
"github.com/grafana/loki/pkg/storage/stores/util"
Expand All @@ -34,9 +35,11 @@ type Compactor struct {

cfg Config
objectClient chunk.ObjectClient

metrics *metrics
}

func NewCompactor(cfg Config, storageConfig storage.Config) (*Compactor, error) {
func NewCompactor(cfg Config, storageConfig storage.Config, r prometheus.Registerer) (*Compactor, error) {
objectClient, err := storage.NewObjectClient(cfg.SharedStoreType, storageConfig)
if err != nil {
return nil, err
Expand All @@ -50,15 +53,27 @@ func NewCompactor(cfg Config, storageConfig storage.Config) (*Compactor, error)
compactor := Compactor{
cfg: cfg,
objectClient: util.NewPrefixedObjectClient(objectClient, shipper.StorageKeyPrefix),
metrics: newMetrics(r),
}

compactor.Service = services.NewTimerService(4*time.Hour, nil, compactor.Run, nil)
return &compactor, nil
}

func (c *Compactor) Run(ctx context.Context) error {
status := statusSuccess
start := time.Now()

defer func() {
c.metrics.compactTablesOperationTotal.WithLabelValues(status).Inc()
if status == statusSuccess {
c.metrics.compactTablesOperationDurationSeconds.Set(time.Since(start).Seconds())
}
}()

_, dirs, err := c.objectClient.List(ctx, "")
if err != nil {
status = statusFailure
return err
}

Expand All @@ -70,13 +85,15 @@ func (c *Compactor) Run(ctx context.Context) error {
for _, tableName := range tables {
table, err := newTable(ctx, filepath.Join(c.cfg.WorkingDirectory, tableName), c.objectClient)
if err != nil {
level.Error(pkg_util.Logger).Log("msg", "failed to initialize table for compaction", "err", err)
status = statusFailure
level.Error(pkg_util.Logger).Log("msg", "failed to initialize table for compaction", "table", tableName, "err", err)
continue
}

err = table.compact()
if err != nil {
level.Error(pkg_util.Logger).Log("msg", "failed to compact files", "err", err)
status = statusFailure
level.Error(pkg_util.Logger).Log("msg", "failed to compact files", "table", tableName, "err", err)
}

// check if context was cancelled before going for next table.
Expand Down
33 changes: 33 additions & 0 deletions pkg/storage/stores/shipper/compactor/metrics.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
package compactor

import (
"github.com/prometheus/client_golang/prometheus"
"github.com/prometheus/client_golang/prometheus/promauto"
)

const (
statusFailure = "failure"
statusSuccess = "success"
)

type metrics struct {
compactTablesOperationTotal *prometheus.CounterVec
compactTablesOperationDurationSeconds prometheus.Gauge
}

func newMetrics(r prometheus.Registerer) *metrics {
m := metrics{
compactTablesOperationTotal: promauto.With(r).NewCounterVec(prometheus.CounterOpts{
Namespace: "loki_boltdb_shipper",
Name: "compact_tables_operation_total",
Help: "Total number of tables compaction done by status",
}, []string{"status"}),
compactTablesOperationDurationSeconds: promauto.With(r).NewGauge(prometheus.GaugeOpts{
Namespace: "loki_boltdb_shipper",
Name: "compact_tables_operation_duration_seconds",
Help: "Time (in seconds) spent in compacting all the tables",
}),
}

return &m
}

0 comments on commit 1bba2a8

Please sign in to comment.