mirror of
https://github.com/cirocosta/monero-exporter.git
synced 2025-01-02 19:40:48 -05:00
c61a0f32d3
Signed-off-by: Ciro S. Costa <utxobr@protonmail.com>
191 lines
3.8 KiB
Go
191 lines
3.8 KiB
Go
package collector
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"time"
|
|
|
|
"github.com/prometheus/client_golang/prometheus"
|
|
|
|
"github.com/cirocosta/go-monero/pkg/rpc/daemon"
|
|
)
|
|
|
|
type OverallCollector struct {
|
|
client *daemon.Client
|
|
metricsC chan<- prometheus.Metric
|
|
|
|
info *daemon.GetInfoResult
|
|
}
|
|
|
|
var _ CustomCollector = (*OverallCollector)(nil)
|
|
|
|
func NewOverallCollector(
|
|
client *daemon.Client, metricsC chan<- prometheus.Metric,
|
|
) *OverallCollector {
|
|
return &OverallCollector{
|
|
client: client,
|
|
metricsC: metricsC,
|
|
}
|
|
}
|
|
|
|
func (c *OverallCollector) Name() string {
|
|
return "overall"
|
|
}
|
|
|
|
func (c *OverallCollector) Collect(ctx context.Context) error {
|
|
err := c.fetchData(ctx)
|
|
if err != nil {
|
|
return fmt.Errorf("fetch data: %w", err)
|
|
}
|
|
|
|
c.collect()
|
|
|
|
return nil
|
|
}
|
|
|
|
func (c *OverallCollector) fetchData(ctx context.Context) error {
|
|
res, err := c.client.GetInfo(ctx)
|
|
if err != nil {
|
|
return fmt.Errorf("get netstats: %w", err)
|
|
}
|
|
|
|
c.info = res
|
|
|
|
return nil
|
|
}
|
|
|
|
func (c *OverallCollector) collect() {
|
|
now := time.Now()
|
|
|
|
c.metricsC <- prometheus.MustNewConstMetric(
|
|
prometheus.NewDesc(
|
|
"monero_info_uptime_seconds_total",
|
|
"for how long this node has been up",
|
|
nil, nil,
|
|
),
|
|
prometheus.GaugeValue,
|
|
float64(now.
|
|
Sub(time.Unix(int64(c.info.StartTime), 0)).
|
|
Seconds()),
|
|
)
|
|
|
|
c.metricsC <- prometheus.MustNewConstMetric(
|
|
prometheus.NewDesc(
|
|
"monero_info_alternative_blocks",
|
|
"number of blocks alternative to the longest",
|
|
nil, nil,
|
|
),
|
|
prometheus.GaugeValue,
|
|
float64(c.info.AltBlocksCount),
|
|
)
|
|
|
|
c.metricsC <- prometheus.MustNewConstMetric(
|
|
prometheus.NewDesc(
|
|
"monero_info_offline",
|
|
"whether the node is offline",
|
|
nil, nil,
|
|
),
|
|
prometheus.GaugeValue,
|
|
boolToFloat64(c.info.Offline),
|
|
)
|
|
|
|
c.metricsC <- prometheus.MustNewConstMetric(
|
|
prometheus.NewDesc(
|
|
"monero_info_mainnet",
|
|
"whether the node is connected to mainnet",
|
|
nil, nil,
|
|
),
|
|
prometheus.GaugeValue,
|
|
boolToFloat64(c.info.Mainnet),
|
|
)
|
|
|
|
c.metricsC <- prometheus.MustNewConstMetric(
|
|
prometheus.NewDesc(
|
|
"monero_info_block_size_limit_bytes",
|
|
"maximum hard limit of a block",
|
|
nil, nil,
|
|
),
|
|
prometheus.GaugeValue,
|
|
float64(c.info.BlockSizeLimit),
|
|
)
|
|
|
|
c.metricsC <- prometheus.MustNewConstMetric(
|
|
prometheus.NewDesc(
|
|
"monero_info_block_size_median_bytes",
|
|
"current median size for computing dynamic fees",
|
|
nil, nil,
|
|
),
|
|
prometheus.GaugeValue,
|
|
float64(c.info.BlockSizeMedian),
|
|
)
|
|
|
|
c.metricsC <- prometheus.MustNewConstMetric(
|
|
prometheus.NewDesc(
|
|
"monero_info_synchronized",
|
|
"whether the node's chain is in sync with the network",
|
|
nil, nil,
|
|
),
|
|
prometheus.GaugeValue,
|
|
boolToFloat64(c.info.Synchronized),
|
|
)
|
|
|
|
c.metricsC <- prometheus.MustNewConstMetric(
|
|
prometheus.NewDesc(
|
|
"monero_info_height",
|
|
"current height of the chain",
|
|
nil, nil,
|
|
),
|
|
prometheus.GaugeValue,
|
|
float64(c.info.Height),
|
|
)
|
|
|
|
c.metricsC <- prometheus.MustNewConstMetric(
|
|
prometheus.NewDesc(
|
|
"monero_info_target_height",
|
|
"target height to achieve to be considered in sync",
|
|
nil, nil,
|
|
),
|
|
prometheus.GaugeValue,
|
|
float64(c.info.TargetHeight),
|
|
)
|
|
|
|
c.metricsC <- prometheus.MustNewConstMetric(
|
|
prometheus.NewDesc(
|
|
"monero_info_rpc_connections",
|
|
"number of rpc connections being served by the node",
|
|
nil, nil,
|
|
),
|
|
prometheus.GaugeValue,
|
|
float64(c.info.RPCConnectionsCount),
|
|
)
|
|
|
|
c.metricsC <- prometheus.MustNewConstMetric(
|
|
prometheus.NewDesc(
|
|
"monero_info_database_size_bytes",
|
|
"size of the monero database",
|
|
nil, nil,
|
|
),
|
|
prometheus.GaugeValue,
|
|
float64(c.info.DatabaseSize),
|
|
)
|
|
|
|
c.metricsC <- prometheus.MustNewConstMetric(
|
|
prometheus.NewDesc(
|
|
"monero_info_free_space_bytes",
|
|
"amount of free space in the partition where "+
|
|
"monero's database is in",
|
|
nil, nil,
|
|
),
|
|
prometheus.GaugeValue,
|
|
float64(c.info.FreeSpace),
|
|
)
|
|
}
|
|
|
|
func boolToFloat64(b bool) float64 {
|
|
if b {
|
|
return 1
|
|
}
|
|
|
|
return 0
|
|
}
|