Skip to content

Commit

Permalink
Add logs to reporter and watcher (#546)
Browse files Browse the repository at this point in the history
* Add logs to reporter and watcher
  • Loading branch information
tobiasbu authored Dec 19, 2022
1 parent b4eb802 commit 507a168
Show file tree
Hide file tree
Showing 5 changed files with 44 additions and 16 deletions.
2 changes: 1 addition & 1 deletion metadata/version.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
package metadata

//Version of Maestro
var Version = "9.6.1"
var Version = "9.15.1"

//KubeVersion is the desired Kubernetes version
var KubeVersion = "v1.13.9"
11 changes: 7 additions & 4 deletions reporters/dogstatsd.go
Original file line number Diff line number Diff line change
Expand Up @@ -49,15 +49,15 @@ func (d *DogStatsD) Report(event string, opts map[string]interface{}) error {
defer d.mutex.RUnlock()
handlerI, prs := handlers.Find(event)
if prs == false {
return fmt.Errorf("reportHandler for %s doesn't exist", event)
return fmt.Errorf("DogStatsD: reportHandler for %s doesn't exist", event)
}
opts[constants.TagRegion] = d.region
handler := handlerI.(func(dogstatsd.Client, string, map[string]string) error)
err := handler(d.client, event, toMapStringString(opts))
if err != nil {
d.logger.Error(err)
return fmt.Errorf("DogStatsD: failed to report event '%s': %w", event, err)
}
return err
return nil
}

// MakeDogStatsD adds a DogStatsD struct to the Reporters' singleton
Expand Down Expand Up @@ -116,13 +116,15 @@ func (d *DogStatsD) restartTicker() {
for range d.ticker.C {
d.mutex.Lock()
if err := d.restartDogStatsdClient(); err != nil {
d.logger.Errorf("DogStatsD: failed to close statsd connection during restart: %s", err.Error())
d.logger.WithError(err).Errorf("DogStatsD: failed to close statsd connection during restart")
}
d.mutex.Unlock()
}
}

func (d *DogStatsD) restartDogStatsdClient() error {
d.logger.Info("Trying to restart the dogstatsd client")

err := d.statsdClient.Close()
if err != nil {
return fmt.Errorf("failed to close statsd connection: %w", err)
Expand All @@ -133,6 +135,7 @@ func (d *DogStatsD) restartDogStatsdClient() error {
return fmt.Errorf("failed to recreate dogstatsd client: %w", err)
}

d.logger.Info("DogStatsD was restarted successfully")
d.statsdClient = c.Client.(*statsd.Client)
d.client = c
return nil
Expand Down
8 changes: 6 additions & 2 deletions reporters/dogstatsd/handlers.go
Original file line number Diff line number Diff line change
Expand Up @@ -71,7 +71,9 @@ func GruStatusHandler(c dogstatsd.Client, event string,
if err != nil {
return err
}
c.Gauge(fmt.Sprintf("gru.%s", opts["status"]), gauge, tags, 1)
if err := c.Gauge(fmt.Sprintf("gru.%s", opts["status"]), gauge, tags, 1); err != nil {
return fmt.Errorf("dogstatsd failed to GRU Status gauge %s: %w", opts["status"], err)
}
return nil
}

Expand Down Expand Up @@ -135,6 +137,8 @@ func GaugeHandler(
if err != nil {
return err
}
c.Gauge(event, gauge, tags, 1)
if err := c.Gauge(event, gauge, tags, 1); err != nil {
return fmt.Errorf("dogstatsd failed to gauge %s: %w", opts["status"], err)
}
return nil
}
11 changes: 9 additions & 2 deletions reporters/reporter.go
Original file line number Diff line number Diff line change
Expand Up @@ -52,8 +52,15 @@ func copyOpts(src map[string]interface{}) map[string]interface{} {

// Report is Reporters' implementation of the Reporter interface
func (r *Reporters) Report(event string, opts map[string]interface{}) error {
var aggregatedErrors []error
for _, reporter := range r.reporters {
reporter.Report(event, copyOpts(opts))
if err := reporter.Report(event, copyOpts(opts)); err != nil {
aggregatedErrors = append(aggregatedErrors, err)
}
}

if len(aggregatedErrors) > 0 {
return fmt.Errorf("failed to report '%s' event: %v", event, aggregatedErrors)
}
return nil
}
Expand All @@ -80,7 +87,7 @@ func MakeReporters(config *viper.Viper, logger *logrus.Logger) {
for k := range GetInstance().reporters {
correctlySet = append(correctlySet, k)
}
logger.Info(fmt.Sprintf("Active reporters: %s", strings.Join(correctlySet, ", ")))
logger.Infof("Active reporters: %s", strings.Join(correctlySet, ", "))
}

// NewReporters ctor
Expand Down
28 changes: 21 additions & 7 deletions watcher/watcher.go
Original file line number Diff line number Diff line change
Expand Up @@ -286,7 +286,11 @@ func (w *Watcher) reportRoomsStatusesRoutine() {
case <-podStateCountTicker.C:
w.PodStatesCount()
case <-roomStatusTicker.C:
_ = w.ReportRoomsStatuses()
w.Logger.Info("Start to report rooms status")
if err := w.ReportRoomsStatuses(); err != nil {
w.Logger.WithError(err).Error("failed to report room status")
}
w.Logger.Info("Finished to report rooms status")
}
}
}
Expand Down Expand Up @@ -461,12 +465,23 @@ func (w *Watcher) ReportRoomsStatuses() error {
}

for _, r := range roomDataSlice {
_ = reporters.Report(reportersConstants.EventGruStatus, map[string]interface{}{
w.Logger.
WithField("gauge", r.Gauge).
Infof("Start reporting %s", r.Status)

err := reporters.Report(reportersConstants.EventGruStatus, map[string]interface{}{
reportersConstants.TagGame: w.GameName,
reportersConstants.TagScheduler: w.SchedulerName,
"status": r.Status,
"gauge": r.Gauge,
})
if err != nil {
w.Logger.
WithError(err).
Errorf("Finished to report status %s with error", r.Status)
} else {
w.Logger.Infof("Finished to report status %s", r.Status)
}
}

return nil
Expand Down Expand Up @@ -741,8 +756,8 @@ func (w *Watcher) RemoveDeadRooms() error {
podsToDelete := w.filterPodsByName(logger, pods, append(roomsNoPingSince, roomsOnOccupiedTimeout...))

startedEvent := models.NewSchedulerEvent(
models.StartRemoveDeadRoomsEventName,
w.SchedulerName,
models.StartRemoveDeadRoomsEventName,
w.SchedulerName,
map[string]interface{}{
"amount": len(podsToDelete),
},
Expand Down Expand Up @@ -806,8 +821,8 @@ func (w *Watcher) RemoveDeadRooms() error {
}

finishedEvent := models.NewSchedulerEvent(
models.FinishedRemoveDeadRoomsEventName,
w.SchedulerName,
models.FinishedRemoveDeadRoomsEventName,
w.SchedulerName,
map[string]interface{}{
models.SuccessMetadataName: err == nil,
})
Expand All @@ -818,7 +833,6 @@ func (w *Watcher) RemoveDeadRooms() error {
}
logger.Info("finish check of dead rooms")


return nil
}

Expand Down

0 comments on commit 507a168

Please sign in to comment.