aboutsummaryrefslogtreecommitdiff
path: root/internal
diff options
context:
space:
mode:
Diffstat (limited to 'internal')
-rw-r--r--internal/manager/manager.go4
-rw-r--r--internal/metrics/metrics.go13
2 files changed, 16 insertions, 1 deletions
diff --git a/internal/manager/manager.go b/internal/manager/manager.go
index 55e72c0..e302b4f 100644
--- a/internal/manager/manager.go
+++ b/internal/manager/manager.go
@@ -209,6 +209,9 @@ func (mgr *Manager) monitorJob(msg monitor.Event) error {
return err
}
mgr.Metrics.LogState(msg.State)
+ for _, err := range msg.Errors {
+ mgr.errorJob(err)
+ }
return nil
}
@@ -226,5 +229,6 @@ func (mgr *Manager) alertJob() error {
func (mgr *Manager) errorJob(err error) error {
mgr.Logger.Debugf("received error: %v\n", err)
+ mgr.Metrics.CountError()
return nil
}
diff --git a/internal/metrics/metrics.go b/internal/metrics/metrics.go
index 113d28c..17e9cce 100644
--- a/internal/metrics/metrics.go
+++ b/internal/metrics/metrics.go
@@ -11,6 +11,7 @@ type Metrics struct {
logIndex *prometheus.GaugeVec
logTimestamp *prometheus.GaugeVec
certificateAlert *prometheus.GaugeVec
+ errorCounter prometheus.Counter
}
func NewMetrics(registry *prometheus.Registry) *Metrics {
@@ -43,9 +44,15 @@ func NewMetrics(registry *prometheus.Registry) *Metrics {
},
[]string{"stored_at"},
),
+ errorCounter: prometheus.NewCounter(
+ prometheus.CounterOpts{
+ Name: "silentct_error_counter",
+ Help: "The number of errors propagated to the main loop.",
+ },
+ ),
}
- registry.MustRegister(m.logSize, m.logIndex, m.logTimestamp, m.certificateAlert)
+ registry.MustRegister(m.logSize, m.logIndex, m.logTimestamp, m.certificateAlert, m.errorCounter)
return m
}
@@ -69,3 +76,7 @@ func (m *Metrics) CertificateAlert(alerts []index.CertificateInfo) {
m.certificateAlert.WithLabelValues(alert.StoredAt).Set(float64(alert.ObservedAt.Unix()))
}
}
+
+func (m *Metrics) CountError() {
+ m.errorCounter.Inc()
+}