mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-13 21:48:19 +00:00
62 lines
1.3 KiB
Go
62 lines
1.3 KiB
Go
|
package node
|
||
|
|
||
|
import (
|
||
|
"fmt"
|
||
|
"os"
|
||
|
|
||
|
"github.com/prometheus/client_golang/prometheus"
|
||
|
)
|
||
|
|
||
|
type bcnodeCollector struct {
|
||
|
DiskBeaconchainBytesTotal *prometheus.Desc
|
||
|
dbPath string
|
||
|
}
|
||
|
|
||
|
func newBeaconNodePromCollector(dbPath string) (*bcnodeCollector, error) {
|
||
|
namespace := "bcnode"
|
||
|
c := &bcnodeCollector{
|
||
|
DiskBeaconchainBytesTotal: prometheus.NewDesc(
|
||
|
prometheus.BuildFQName(namespace, "", "disk_beaconchain_bytes_total"),
|
||
|
"Total hard disk space used by the beaconchain database, in bytes.",
|
||
|
nil,
|
||
|
nil,
|
||
|
),
|
||
|
dbPath: dbPath,
|
||
|
}
|
||
|
_, err := c.getCurrentDbBytes()
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return c, prometheus.Register(c)
|
||
|
}
|
||
|
|
||
|
func (bc *bcnodeCollector) Describe(ch chan<- *prometheus.Desc) {
|
||
|
ch <- bc.DiskBeaconchainBytesTotal
|
||
|
}
|
||
|
|
||
|
func (bc *bcnodeCollector) Collect(ch chan<- prometheus.Metric) {
|
||
|
dbBytes, err := bc.getCurrentDbBytes()
|
||
|
if err != nil {
|
||
|
log.Warn(err)
|
||
|
return
|
||
|
}
|
||
|
|
||
|
ch <- prometheus.MustNewConstMetric(
|
||
|
bc.DiskBeaconchainBytesTotal,
|
||
|
prometheus.GaugeValue,
|
||
|
dbBytes,
|
||
|
)
|
||
|
}
|
||
|
|
||
|
func (bc *bcnodeCollector) getCurrentDbBytes() (float64, error) {
|
||
|
fs, err := os.Stat(bc.dbPath)
|
||
|
if err != nil {
|
||
|
return 0, fmt.Errorf("could not collect database file size for prometheus, path=%s, err=%s", bc.dbPath, err)
|
||
|
}
|
||
|
return float64(fs.Size()), nil
|
||
|
}
|
||
|
|
||
|
func (bc *bcnodeCollector) unregister() {
|
||
|
prometheus.Unregister(bc)
|
||
|
}
|