mirror of
https://github.com/cirocosta/monero-exporter.git
synced 2024-10-01 08:25:41 -04:00
debdce3fb2
this is a big refactor, essentially rewriting the custom collector from scratch, and as such, creating a new dashboard based on the new metrics. Signed-off-by: Ciro S. Costa <utxobr@protonmail.com>
88 lines
1.6 KiB
Go
88 lines
1.6 KiB
Go
package collector
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"time"
|
|
|
|
"github.com/prometheus/client_golang/prometheus"
|
|
|
|
"github.com/cirocosta/go-monero/pkg/rpc/daemon"
|
|
)
|
|
|
|
type RPCCollector struct {
|
|
client *daemon.Client
|
|
metricsC chan<- prometheus.Metric
|
|
|
|
accessTracking *daemon.RPCAccessTrackingResult
|
|
}
|
|
|
|
var _ CustomCollector = (*RPCCollector)(nil)
|
|
|
|
func NewRPCCollector(
|
|
client *daemon.Client, metricsC chan<- prometheus.Metric,
|
|
) *RPCCollector {
|
|
return &RPCCollector{
|
|
client: client,
|
|
metricsC: metricsC,
|
|
}
|
|
}
|
|
|
|
func (c *RPCCollector) Name() string {
|
|
return "rpc"
|
|
}
|
|
|
|
func (c *RPCCollector) Collect(ctx context.Context) error {
|
|
err := c.fetchData(ctx)
|
|
if err != nil {
|
|
return fmt.Errorf("fetch data: %w", err)
|
|
}
|
|
|
|
c.collectRPC()
|
|
|
|
return nil
|
|
}
|
|
|
|
func (c *RPCCollector) collectRPC() {
|
|
countDesc := prometheus.NewDesc(
|
|
"monero_rpc_hits_total",
|
|
"number of hits that a particular rpc "+
|
|
"method had since startup",
|
|
[]string{"method"}, nil,
|
|
)
|
|
|
|
timeDesc := prometheus.NewDesc(
|
|
"monero_rpc_seconds_total",
|
|
"amount of time spent service the method "+
|
|
"since startup",
|
|
[]string{"method"}, nil,
|
|
)
|
|
|
|
for _, d := range c.accessTracking.Data {
|
|
c.metricsC <- prometheus.MustNewConstMetric(
|
|
countDesc,
|
|
prometheus.GaugeValue,
|
|
float64(d.Count),
|
|
d.RPC,
|
|
)
|
|
|
|
c.metricsC <- prometheus.MustNewConstMetric(
|
|
timeDesc,
|
|
prometheus.GaugeValue,
|
|
time.Duration(int64(d.Time)).Seconds(),
|
|
d.RPC,
|
|
)
|
|
}
|
|
}
|
|
|
|
func (c *RPCCollector) fetchData(ctx context.Context) error {
|
|
res, err := c.client.RPCAccessTracking(ctx)
|
|
if err != nil {
|
|
return fmt.Errorf("rpc access tracking: %w", err)
|
|
}
|
|
|
|
c.accessTracking = res
|
|
|
|
return nil
|
|
}
|