prom and influx support
This commit is contained in:
parent
0ab3de2ec4
commit
26e2771229
|
|
@ -155,7 +155,7 @@ func (u *InfluxUnifi) Run(c poller.Collect) error {
|
|||
var err error
|
||||
|
||||
u.setConfigDefaults()
|
||||
|
||||
|
||||
_, err = url.Parse(u.Config.URL)
|
||||
if err != nil {
|
||||
u.LogErrorf("invalid influx URL: %v", err)
|
||||
|
|
@ -368,6 +368,8 @@ func (u *InfluxUnifi) switchExport(r report, v any) { //nolint:cyclop
|
|||
u.batchUAP(r, v)
|
||||
case *unifi.USW:
|
||||
u.batchUSW(r, v)
|
||||
case *unifi.PDU:
|
||||
u.batchPDU(r, v)
|
||||
case *unifi.USG:
|
||||
u.batchUSG(r, v)
|
||||
case *unifi.UXG:
|
||||
|
|
|
|||
|
|
@ -0,0 +1,120 @@
|
|||
package influxunifi
|
||||
|
||||
import (
|
||||
"github.com/unpoller/unifi"
|
||||
)
|
||||
|
||||
// pduT is used as a name for printed/logged counters.
|
||||
const pduT = item("PDU")
|
||||
|
||||
// batchPDU generates Unifi PDU data points for InfluxDB.
|
||||
// These points can be passed directly to influx.
|
||||
func (u *InfluxUnifi) batchPDU(r report, s *unifi.PDU) {
|
||||
if !s.Adopted.Val || s.Locating.Val {
|
||||
return
|
||||
}
|
||||
|
||||
tags := map[string]string{
|
||||
"mac": s.Mac,
|
||||
"site_name": s.SiteName,
|
||||
"source": s.SourceName,
|
||||
"name": s.Name,
|
||||
"version": s.Version,
|
||||
"model": s.Model,
|
||||
"serial": s.Serial,
|
||||
"type": s.Type,
|
||||
}
|
||||
fields := Combine(
|
||||
u.batchPDUstat(s.Stat.Sw),
|
||||
u.batchSysStats(s.SysStats, s.SystemStats),
|
||||
map[string]any{
|
||||
"guest-num_sta": s.GuestNumSta.Val,
|
||||
"ip": s.IP,
|
||||
"bytes": s.Bytes.Val,
|
||||
"last_seen": s.LastSeen.Val,
|
||||
"rx_bytes": s.RxBytes.Val,
|
||||
"tx_bytes": s.TxBytes.Val,
|
||||
"uptime": s.Uptime.Val,
|
||||
"state": s.State.Val,
|
||||
"user-num_sta": s.UserNumSta.Val,
|
||||
"upgradeable": s.Upgradeable.Val,
|
||||
"outlet_ac_power_budget": s.OutletACPowerBudget.Val,
|
||||
"outlet_ac_power_consumption": s.OutletACPowerConsumption.Val,
|
||||
"outlet_enabled": s.OutletEnabled.Val,
|
||||
"overheating": s.Overheating.Val,
|
||||
"power_source": s.PowerSource.Val,
|
||||
"total_max_power": s.TotalMaxPower.Val,
|
||||
})
|
||||
|
||||
r.addCount(pduT)
|
||||
r.send(&metric{Table: "pdu", Tags: tags, Fields: fields})
|
||||
u.batchPortTable(r, tags, s.PortTable)
|
||||
|
||||
for _, oo := range s.OutletOverrides {
|
||||
oot := cleanTags(map[string]string{
|
||||
"mac": s.Mac,
|
||||
"site_name": s.SiteName,
|
||||
"source": s.SourceName,
|
||||
"name": s.Name,
|
||||
"version": s.Version,
|
||||
"model": s.Model,
|
||||
"serial": s.Serial,
|
||||
"type": s.Type,
|
||||
"ip": s.IP,
|
||||
"outlet_index": oo.Index.Txt,
|
||||
"outlet_name": oo.Name,
|
||||
})
|
||||
ood := map[string]any{
|
||||
"cycle_enabled": oo.CycleEnabled.Val,
|
||||
"relay_state": oo.RelayState.Val,
|
||||
}
|
||||
r.send(&metric{Table: "pdu.outlet_overrides", Tags: oot, Fields: ood})
|
||||
}
|
||||
|
||||
for _, ot := range s.OutletTable {
|
||||
ott := cleanTags(map[string]string{
|
||||
"mac": s.Mac,
|
||||
"site_name": s.SiteName,
|
||||
"source": s.SourceName,
|
||||
"name": s.Name,
|
||||
"version": s.Version,
|
||||
"model": s.Model,
|
||||
"serial": s.Serial,
|
||||
"type": s.Type,
|
||||
"ip": s.IP,
|
||||
"outlet_index": ot.Index.Txt,
|
||||
"outlet_name": ot.Name,
|
||||
})
|
||||
otd := map[string]any{
|
||||
"cycle_enabled": ot.CycleEnabled.Val,
|
||||
"relay_state": ot.RelayState.Val,
|
||||
"outlet_caps": ot.OutletCaps.Val,
|
||||
"outlet_power_factor": ot.OutletPowerFactor.Val,
|
||||
"outlet_current": ot.OutletCurrent.Val,
|
||||
"outlet_power": ot.OutletPower.Val,
|
||||
"outlet_voltage": ot.OutletVoltage.Val,
|
||||
}
|
||||
r.send(&metric{Table: "pdu.outlet_table", Tags: ott, Fields: otd})
|
||||
}
|
||||
}
|
||||
|
||||
func (u *InfluxUnifi) batchPDUstat(sw *unifi.Sw) map[string]any {
|
||||
if sw == nil {
|
||||
return map[string]any{}
|
||||
}
|
||||
|
||||
return map[string]any{
|
||||
"stat_bytes": sw.Bytes.Val,
|
||||
"stat_rx_bytes": sw.RxBytes.Val,
|
||||
"stat_rx_crypts": sw.RxCrypts.Val,
|
||||
"stat_rx_dropped": sw.RxDropped.Val,
|
||||
"stat_rx_errors": sw.RxErrors.Val,
|
||||
"stat_rx_frags": sw.RxFrags.Val,
|
||||
"stat_rx_packets": sw.TxPackets.Val,
|
||||
"stat_tx_bytes": sw.TxBytes.Val,
|
||||
"stat_tx_dropped": sw.TxDropped.Val,
|
||||
"stat_tx_errors": sw.TxErrors.Val,
|
||||
"stat_tx_packets": sw.TxPackets.Val,
|
||||
"stat_tx_retries": sw.TxRetries.Val,
|
||||
}
|
||||
}
|
||||
|
|
@ -39,6 +39,7 @@ type promUnifi struct {
|
|||
UAP *uap
|
||||
USG *usg
|
||||
USW *usw
|
||||
PDU *pdu
|
||||
Site *site
|
||||
RogueAP *rogueap
|
||||
// This interface is passed to the Collect() method. The Collect method uses
|
||||
|
|
@ -85,6 +86,7 @@ type Report struct {
|
|||
Zeros int // Total count of metrics equal to zero.
|
||||
USG int // Total count of USG devices.
|
||||
USW int // Total count of USW devices.
|
||||
PDU int // Total count of PDU devices.
|
||||
UAP int // Total count of UAP devices.
|
||||
UDM int // Total count of UDM devices.
|
||||
UXG int // Total count of UXG devices.
|
||||
|
|
@ -152,6 +154,7 @@ func (u *promUnifi) Run(c poller.Collect) error {
|
|||
u.UAP = descUAP(u.Namespace + "_device_")
|
||||
u.USG = descUSG(u.Namespace + "_device_")
|
||||
u.USW = descUSW(u.Namespace + "_device_")
|
||||
u.PDU = descPDU(u.Namespace + "_device_")
|
||||
u.Site = descSite(u.Namespace + "_site_")
|
||||
u.RogueAP = descRogueAP(u.Namespace + "_rogueap_")
|
||||
|
||||
|
|
@ -235,7 +238,7 @@ func (t *target) Describe(ch chan<- *prometheus.Desc) {
|
|||
// Describe satisfies the prometheus Collector. This returns all of the
|
||||
// metric descriptions that this packages produces.
|
||||
func (u *promUnifi) Describe(ch chan<- *prometheus.Desc) {
|
||||
for _, f := range []any{u.Client, u.Device, u.UAP, u.USG, u.USW, u.Site} {
|
||||
for _, f := range []any{u.Client, u.Device, u.UAP, u.USG, u.USW, u.PDU, u.Site} {
|
||||
v := reflect.Indirect(reflect.ValueOf(f))
|
||||
|
||||
// Loop each struct member and send it to the provided channel.
|
||||
|
|
@ -357,6 +360,9 @@ func (u *promUnifi) switchExport(r report, v any) {
|
|||
case *unifi.USW:
|
||||
r.addUSW()
|
||||
u.exportUSW(r, v)
|
||||
case *unifi.PDU:
|
||||
r.addPDU()
|
||||
u.exportPDU(r, v)
|
||||
case *unifi.USG:
|
||||
r.addUSG()
|
||||
u.exportUSG(r, v)
|
||||
|
|
|
|||
|
|
@ -0,0 +1,276 @@
|
|||
package promunifi
|
||||
|
||||
import (
|
||||
"github.com/prometheus/client_golang/prometheus"
|
||||
"github.com/unpoller/unifi"
|
||||
)
|
||||
|
||||
type pdu struct {
|
||||
// Switch "total" traffic stats
|
||||
SwRxPackets *prometheus.Desc
|
||||
SwRxBytes *prometheus.Desc
|
||||
SwRxErrors *prometheus.Desc
|
||||
SwRxDropped *prometheus.Desc
|
||||
SwRxCrypts *prometheus.Desc
|
||||
SwRxFrags *prometheus.Desc
|
||||
SwTxPackets *prometheus.Desc
|
||||
SwTxBytes *prometheus.Desc
|
||||
SwTxErrors *prometheus.Desc
|
||||
SwTxDropped *prometheus.Desc
|
||||
SwTxRetries *prometheus.Desc
|
||||
SwRxMulticast *prometheus.Desc
|
||||
SwRxBroadcast *prometheus.Desc
|
||||
SwTxMulticast *prometheus.Desc
|
||||
SwTxBroadcast *prometheus.Desc
|
||||
SwBytes *prometheus.Desc
|
||||
// Port data.
|
||||
PoeCurrent *prometheus.Desc
|
||||
PoePower *prometheus.Desc
|
||||
PoeVoltage *prometheus.Desc
|
||||
RxBroadcast *prometheus.Desc
|
||||
RxBytes *prometheus.Desc
|
||||
RxBytesR *prometheus.Desc
|
||||
RxDropped *prometheus.Desc
|
||||
RxErrors *prometheus.Desc
|
||||
RxMulticast *prometheus.Desc
|
||||
RxPackets *prometheus.Desc
|
||||
Satisfaction *prometheus.Desc
|
||||
Speed *prometheus.Desc
|
||||
TxBroadcast *prometheus.Desc
|
||||
TxBytes *prometheus.Desc
|
||||
TxBytesR *prometheus.Desc
|
||||
TxDropped *prometheus.Desc
|
||||
TxErrors *prometheus.Desc
|
||||
TxMulticast *prometheus.Desc
|
||||
TxPackets *prometheus.Desc
|
||||
SFPCurrent *prometheus.Desc
|
||||
SFPRxPower *prometheus.Desc
|
||||
SFPTemperature *prometheus.Desc
|
||||
SFPTxPower *prometheus.Desc
|
||||
SFPVoltage *prometheus.Desc
|
||||
// other
|
||||
Upgradeable *prometheus.Desc
|
||||
// power
|
||||
CycleEnabled *prometheus.Desc
|
||||
RelayState *prometheus.Desc
|
||||
OutletCaps *prometheus.Desc
|
||||
OutletCurrent *prometheus.Desc
|
||||
OutletPower *prometheus.Desc
|
||||
OutletPowerFactor *prometheus.Desc
|
||||
OutletVoltage *prometheus.Desc
|
||||
}
|
||||
|
||||
func descPDU(ns string) *pdu {
|
||||
pns := ns + "port_"
|
||||
sfp := pns + "sfp_"
|
||||
labelS := []string{"site_name", "name", "source"}
|
||||
labelP := []string{"port_id", "port_num", "port_name", "port_mac", "port_ip", "site_name", "name", "source"}
|
||||
labelF := []string{
|
||||
"sfp_part", "sfp_vendor", "sfp_serial", "sfp_compliance",
|
||||
"port_id", "port_num", "port_name", "port_mac", "port_ip", "site_name", "name", "source",
|
||||
}
|
||||
nd := prometheus.NewDesc
|
||||
|
||||
return &pdu{
|
||||
// This data may be derivable by sum()ing the port data.
|
||||
SwRxPackets: nd(ns+"switch_receive_packets_total", "Switch Packets Received Total", labelS, nil),
|
||||
SwRxBytes: nd(ns+"switch_receive_bytes_total", "Switch Bytes Received Total", labelS, nil),
|
||||
SwRxErrors: nd(ns+"switch_receive_errors_total", "Switch Errors Received Total", labelS, nil),
|
||||
SwRxDropped: nd(ns+"switch_receive_dropped_total", "Switch Dropped Received Total", labelS, nil),
|
||||
SwRxCrypts: nd(ns+"switch_receive_crypts_total", "Switch Crypts Received Total", labelS, nil),
|
||||
SwRxFrags: nd(ns+"switch_receive_frags_total", "Switch Frags Received Total", labelS, nil),
|
||||
SwTxPackets: nd(ns+"switch_transmit_packets_total", "Switch Packets Transmit Total", labelS, nil),
|
||||
SwTxBytes: nd(ns+"switch_transmit_bytes_total", "Switch Bytes Transmit Total", labelS, nil),
|
||||
SwTxErrors: nd(ns+"switch_transmit_errors_total", "Switch Errors Transmit Total", labelS, nil),
|
||||
SwTxDropped: nd(ns+"switch_transmit_dropped_total", "Switch Dropped Transmit Total", labelS, nil),
|
||||
SwTxRetries: nd(ns+"switch_transmit_retries_total", "Switch Retries Transmit Total", labelS, nil),
|
||||
SwRxMulticast: nd(ns+"switch_receive_multicast_total", "Switch Multicast Receive Total", labelS, nil),
|
||||
SwRxBroadcast: nd(ns+"switch_receive_broadcast_total", "Switch Broadcast Receive Total", labelS, nil),
|
||||
SwTxMulticast: nd(ns+"switch_transmit_multicast_total", "Switch Multicast Transmit Total", labelS, nil),
|
||||
SwTxBroadcast: nd(ns+"switch_transmit_broadcast_total", "Switch Broadcast Transmit Total", labelS, nil),
|
||||
SwBytes: nd(ns+"switch_bytes_total", "Switch Bytes Transferred Total", labelS, nil),
|
||||
// per-port data
|
||||
PoeCurrent: nd(pns+"poe_amperes", "POE Current", labelP, nil),
|
||||
PoePower: nd(pns+"poe_watts", "POE Power", labelP, nil),
|
||||
PoeVoltage: nd(pns+"poe_volts", "POE Voltage", labelP, nil),
|
||||
RxBroadcast: nd(pns+"receive_broadcast_total", "Receive Broadcast", labelP, nil),
|
||||
RxBytes: nd(pns+"receive_bytes_total", "Total Receive Bytes", labelP, nil),
|
||||
RxBytesR: nd(pns+"receive_rate_bytes", "Receive Bytes Rate", labelP, nil),
|
||||
RxDropped: nd(pns+"receive_dropped_total", "Total Receive Dropped", labelP, nil),
|
||||
RxErrors: nd(pns+"receive_errors_total", "Total Receive Errors", labelP, nil),
|
||||
RxMulticast: nd(pns+"receive_multicast_total", "Total Receive Multicast", labelP, nil),
|
||||
RxPackets: nd(pns+"receive_packets_total", "Total Receive Packets", labelP, nil),
|
||||
Satisfaction: nd(pns+"satisfaction_ratio", "Satisfaction", labelP, nil),
|
||||
Speed: nd(pns+"port_speed_bps", "Speed", labelP, nil),
|
||||
TxBroadcast: nd(pns+"transmit_broadcast_total", "Total Transmit Broadcast", labelP, nil),
|
||||
TxBytes: nd(pns+"transmit_bytes_total", "Total Transmit Bytes", labelP, nil),
|
||||
TxBytesR: nd(pns+"transmit_rate_bytes", "Transmit Bytes Rate", labelP, nil),
|
||||
TxDropped: nd(pns+"transmit_dropped_total", "Total Transmit Dropped", labelP, nil),
|
||||
TxErrors: nd(pns+"transmit_errors_total", "Total Transmit Errors", labelP, nil),
|
||||
TxMulticast: nd(pns+"transmit_multicast_total", "Total Tranmist Multicast", labelP, nil),
|
||||
TxPackets: nd(pns+"transmit_packets_total", "Total Transmit Packets", labelP, nil),
|
||||
SFPCurrent: nd(sfp+"current", "SFP Current", labelF, nil),
|
||||
SFPRxPower: nd(sfp+"rx_power", "SFP Receive Power", labelF, nil),
|
||||
SFPTemperature: nd(sfp+"temperature", "SFP Temperature", labelF, nil),
|
||||
SFPTxPower: nd(sfp+"tx_power", "SFP Transmit Power", labelF, nil),
|
||||
SFPVoltage: nd(sfp+"voltage", "SFP Voltage", labelF, nil),
|
||||
// other data
|
||||
Upgradeable: nd(ns+"upgradeable", "Upgrade-able", labelS, nil),
|
||||
}
|
||||
}
|
||||
|
||||
func (u *promUnifi) exportPDU(r report, d *unifi.PDU) {
|
||||
if !d.Adopted.Val || d.Locating.Val {
|
||||
return
|
||||
}
|
||||
|
||||
labels := []string{d.Type, d.SiteName, d.Name, d.SourceName}
|
||||
infoLabels := []string{d.Version, d.Model, d.Serial, d.Mac, d.IP, d.ID}
|
||||
|
||||
u.exportPDUstats(r, labels, d.Stat.Sw)
|
||||
u.exportPDUPrtTable(r, labels, d.PortTable)
|
||||
u.exportPDUOutletTable(r, labels, d.OutletTable, d.OutletOverrides)
|
||||
u.exportBYTstats(r, labels, d.TxBytes, d.RxBytes)
|
||||
u.exportSYSstats(r, labels, d.SysStats, d.SystemStats)
|
||||
u.exportSTAcount(r, labels, d.UserNumSta, d.GuestNumSta)
|
||||
r.send([]*metric{
|
||||
{u.Device.Info, gauge, 1.0, append(labels, infoLabels...)},
|
||||
{u.Device.Uptime, gauge, d.Uptime, labels},
|
||||
{u.Device.Upgradeable, gauge, d.Upgradeable.Val, labels},
|
||||
})
|
||||
|
||||
// Switch System Data.
|
||||
if d.OutletACPowerConsumption.Txt != "" {
|
||||
r.send([]*metric{{u.Device.OutletACPowerConsumption, gauge, d.OutletACPowerConsumption, labels}})
|
||||
}
|
||||
if d.PowerSource.Txt != "" {
|
||||
r.send([]*metric{{u.Device.PowerSource, gauge, d.PowerSource, labels}})
|
||||
}
|
||||
if d.TotalMaxPower.Txt != "" {
|
||||
r.send([]*metric{{u.Device.TotalMaxPower, gauge, d.TotalMaxPower, labels}})
|
||||
}
|
||||
}
|
||||
|
||||
// Switch Stats.
|
||||
func (u *promUnifi) exportPDUstats(r report, labels []string, sw *unifi.Sw) {
|
||||
if sw == nil {
|
||||
return
|
||||
}
|
||||
|
||||
labelS := labels[1:]
|
||||
|
||||
r.send([]*metric{
|
||||
{u.PDU.SwRxPackets, counter, sw.RxPackets, labelS},
|
||||
{u.PDU.SwRxBytes, counter, sw.RxBytes, labelS},
|
||||
{u.PDU.SwRxErrors, counter, sw.RxErrors, labelS},
|
||||
{u.PDU.SwRxDropped, counter, sw.RxDropped, labelS},
|
||||
{u.PDU.SwRxCrypts, counter, sw.RxCrypts, labelS},
|
||||
{u.PDU.SwRxFrags, counter, sw.RxFrags, labelS},
|
||||
{u.PDU.SwTxPackets, counter, sw.TxPackets, labelS},
|
||||
{u.PDU.SwTxBytes, counter, sw.TxBytes, labelS},
|
||||
{u.PDU.SwTxErrors, counter, sw.TxErrors, labelS},
|
||||
{u.PDU.SwTxDropped, counter, sw.TxDropped, labelS},
|
||||
{u.PDU.SwTxRetries, counter, sw.TxRetries, labelS},
|
||||
{u.PDU.SwRxMulticast, counter, sw.RxMulticast, labelS},
|
||||
{u.PDU.SwRxBroadcast, counter, sw.RxBroadcast, labelS},
|
||||
{u.PDU.SwTxMulticast, counter, sw.TxMulticast, labelS},
|
||||
{u.PDU.SwTxBroadcast, counter, sw.TxBroadcast, labelS},
|
||||
{u.PDU.SwBytes, counter, sw.Bytes, labelS},
|
||||
})
|
||||
}
|
||||
|
||||
// Switch Port Table.
|
||||
func (u *promUnifi) exportPDUPrtTable(r report, labels []string, pt []unifi.Port) {
|
||||
// Per-port data on a switch
|
||||
for _, p := range pt {
|
||||
if !u.DeadPorts && (!p.Up.Val || !p.Enable.Val) {
|
||||
continue
|
||||
}
|
||||
|
||||
// Copy labels, and add four new ones.
|
||||
labelP := []string{
|
||||
labels[2] + " Port " + p.PortIdx.Txt, p.PortIdx.Txt,
|
||||
p.Name, p.Mac, p.IP, labels[1], labels[2], labels[3],
|
||||
}
|
||||
|
||||
if p.PoeEnable.Val && p.PortPoe.Val {
|
||||
r.send([]*metric{
|
||||
{u.PDU.PoeCurrent, gauge, p.PoeCurrent, labelP},
|
||||
{u.PDU.PoePower, gauge, p.PoePower, labelP},
|
||||
{u.PDU.PoeVoltage, gauge, p.PoeVoltage, labelP},
|
||||
})
|
||||
}
|
||||
|
||||
if p.SFPFound.Val {
|
||||
labelF := []string{
|
||||
p.SFPPart, p.SFPVendor, p.SFPSerial, p.SFPCompliance,
|
||||
labelP[0], labelP[1], labelP[2], labelP[3], labelP[4], labelP[5], labelP[6], labelP[7],
|
||||
}
|
||||
|
||||
r.send([]*metric{
|
||||
{u.PDU.SFPCurrent, gauge, p.SFPCurrent.Val, labelF},
|
||||
{u.PDU.SFPVoltage, gauge, p.SFPVoltage.Val, labelF},
|
||||
{u.PDU.SFPTemperature, gauge, p.SFPTemperature.Val, labelF},
|
||||
{u.PDU.SFPRxPower, gauge, p.SFPRxpower.Val, labelF},
|
||||
{u.PDU.SFPTxPower, gauge, p.SFPTxpower.Val, labelF},
|
||||
})
|
||||
}
|
||||
|
||||
r.send([]*metric{
|
||||
{u.PDU.RxBroadcast, counter, p.RxBroadcast, labelP},
|
||||
{u.PDU.RxBytes, counter, p.RxBytes, labelP},
|
||||
{u.PDU.RxBytesR, gauge, p.RxBytesR, labelP},
|
||||
{u.PDU.RxDropped, counter, p.RxDropped, labelP},
|
||||
{u.PDU.RxErrors, counter, p.RxErrors, labelP},
|
||||
{u.PDU.RxMulticast, counter, p.RxMulticast, labelP},
|
||||
{u.PDU.RxPackets, counter, p.RxPackets, labelP},
|
||||
{u.PDU.Satisfaction, gauge, p.Satisfaction.Val / 100.0, labelP},
|
||||
{u.PDU.Speed, gauge, p.Speed.Val * 1000000, labelP},
|
||||
{u.PDU.TxBroadcast, counter, p.TxBroadcast, labelP},
|
||||
{u.PDU.TxBytes, counter, p.TxBytes, labelP},
|
||||
{u.PDU.TxBytesR, gauge, p.TxBytesR, labelP},
|
||||
{u.PDU.TxDropped, counter, p.TxDropped, labelP},
|
||||
{u.PDU.TxErrors, counter, p.TxErrors, labelP},
|
||||
{u.PDU.TxMulticast, counter, p.TxMulticast, labelP},
|
||||
{u.PDU.TxPackets, counter, p.TxPackets, labelP},
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
// Switch Port Table.
|
||||
func (u *promUnifi) exportPDUOutletTable(r report, labels []string, ot []unifi.OutletTable, oto []unifi.OutletOverride) {
|
||||
// Per-outlet data on a switch
|
||||
for _, o := range ot {
|
||||
|
||||
// Copy labels, and add four new ones.
|
||||
labelOutlet := []string{
|
||||
labels[2] + " Outlet " + o.Index.Txt, o.Index.Txt,
|
||||
o.Name, labels[1], labels[2], labels[3],
|
||||
}
|
||||
|
||||
r.send([]*metric{
|
||||
{u.PDU.CycleEnabled, counter, o.CycleEnabled, labelOutlet},
|
||||
{u.PDU.RelayState, counter, o.RelayState, labelOutlet},
|
||||
{u.PDU.OutletCaps, counter, o.OutletCaps, labelOutlet},
|
||||
{u.PDU.OutletCurrent, gauge, o.OutletCurrent, labelOutlet},
|
||||
{u.PDU.OutletPower, counter, o.OutletPower, labelOutlet},
|
||||
{u.PDU.OutletPowerFactor, counter, o.OutletPowerFactor, labelOutlet},
|
||||
{u.PDU.OutletVoltage, counter, o.OutletVoltage, labelOutlet},
|
||||
})
|
||||
}
|
||||
|
||||
// Per-outlet data on a switch
|
||||
for _, o := range oto {
|
||||
|
||||
// Copy labels, and add four new ones.
|
||||
labelOutlet := []string{
|
||||
labels[2] + " Outlet Override " + o.Index.Txt, o.Index.Txt,
|
||||
o.Name, labels[1], labels[2], labels[3],
|
||||
}
|
||||
|
||||
r.send([]*metric{
|
||||
{u.PDU.CycleEnabled, counter, o.CycleEnabled, labelOutlet},
|
||||
{u.PDU.RelayState, counter, o.RelayState, labelOutlet},
|
||||
})
|
||||
}
|
||||
}
|
||||
|
|
@ -24,6 +24,7 @@ type report interface {
|
|||
addUSG()
|
||||
addUAP()
|
||||
addUSW()
|
||||
addPDU()
|
||||
}
|
||||
|
||||
// Satisfy gomnd.
|
||||
|
|
@ -76,6 +77,10 @@ func (r *Report) addUSW() {
|
|||
r.USW++
|
||||
}
|
||||
|
||||
func (r *Report) addPDU() {
|
||||
r.PDU++
|
||||
}
|
||||
|
||||
func (r *Report) addUAP() {
|
||||
r.UAP++
|
||||
}
|
||||
|
|
|
|||
|
|
@ -7,29 +7,31 @@ import (
|
|||
|
||||
// These are shared by all four device types: UDM, UAP, USG, USW.
|
||||
type unifiDevice struct {
|
||||
Info *prometheus.Desc
|
||||
Uptime *prometheus.Desc
|
||||
Temperature *prometheus.Desc
|
||||
Storage *prometheus.Desc
|
||||
TotalMaxPower *prometheus.Desc // sw only
|
||||
FanLevel *prometheus.Desc // sw only
|
||||
TotalTxBytes *prometheus.Desc
|
||||
TotalRxBytes *prometheus.Desc
|
||||
TotalBytes *prometheus.Desc
|
||||
BytesR *prometheus.Desc // ap only
|
||||
BytesD *prometheus.Desc // ap only
|
||||
TxBytesD *prometheus.Desc // ap only
|
||||
RxBytesD *prometheus.Desc // ap only
|
||||
Counter *prometheus.Desc
|
||||
Loadavg1 *prometheus.Desc
|
||||
Loadavg5 *prometheus.Desc
|
||||
Loadavg15 *prometheus.Desc
|
||||
MemBuffer *prometheus.Desc
|
||||
MemTotal *prometheus.Desc
|
||||
MemUsed *prometheus.Desc
|
||||
CPU *prometheus.Desc
|
||||
Mem *prometheus.Desc
|
||||
Upgradeable *prometheus.Desc
|
||||
Info *prometheus.Desc
|
||||
Uptime *prometheus.Desc
|
||||
Temperature *prometheus.Desc
|
||||
Storage *prometheus.Desc
|
||||
TotalMaxPower *prometheus.Desc // sw only
|
||||
OutletACPowerConsumption *prometheus.Desc // pdu only
|
||||
PowerSource *prometheus.Desc // pdu only
|
||||
FanLevel *prometheus.Desc // sw only
|
||||
TotalTxBytes *prometheus.Desc
|
||||
TotalRxBytes *prometheus.Desc
|
||||
TotalBytes *prometheus.Desc
|
||||
BytesR *prometheus.Desc // ap only
|
||||
BytesD *prometheus.Desc // ap only
|
||||
TxBytesD *prometheus.Desc // ap only
|
||||
RxBytesD *prometheus.Desc // ap only
|
||||
Counter *prometheus.Desc
|
||||
Loadavg1 *prometheus.Desc
|
||||
Loadavg5 *prometheus.Desc
|
||||
Loadavg15 *prometheus.Desc
|
||||
MemBuffer *prometheus.Desc
|
||||
MemTotal *prometheus.Desc
|
||||
MemUsed *prometheus.Desc
|
||||
CPU *prometheus.Desc
|
||||
Mem *prometheus.Desc
|
||||
Upgradeable *prometheus.Desc
|
||||
}
|
||||
|
||||
func descDevice(ns string) *unifiDevice {
|
||||
|
|
@ -43,25 +45,27 @@ func descDevice(ns string) *unifiDevice {
|
|||
append(labels, "temp_area", "temp_type"), nil),
|
||||
Storage: prometheus.NewDesc(ns+"storage", "Storage",
|
||||
append(labels, "mountpoint", "storage_name", "storage_reading"), nil),
|
||||
TotalMaxPower: prometheus.NewDesc(ns+"max_power_total", "Total Max Power", labels, nil),
|
||||
FanLevel: prometheus.NewDesc(ns+"fan_level", "Fan Level", labels, nil),
|
||||
TotalTxBytes: prometheus.NewDesc(ns+"transmit_bytes_total", "Total Transmitted Bytes", labels, nil),
|
||||
TotalRxBytes: prometheus.NewDesc(ns+"receive_bytes_total", "Total Received Bytes", labels, nil),
|
||||
TotalBytes: prometheus.NewDesc(ns+"bytes_total", "Total Bytes Transferred", labels, nil),
|
||||
BytesR: prometheus.NewDesc(ns+"rate_bytes", "Transfer Rate", labels, nil),
|
||||
BytesD: prometheus.NewDesc(ns+"d_bytes", "Total Bytes D???", labels, nil),
|
||||
TxBytesD: prometheus.NewDesc(ns+"d_tranmsit_bytes", "Transmit Bytes D???", labels, nil),
|
||||
RxBytesD: prometheus.NewDesc(ns+"d_receive_bytes", "Receive Bytes D???", labels, nil),
|
||||
Counter: prometheus.NewDesc(ns+"stations", "Number of Stations", append(labels, "station_type"), nil),
|
||||
Loadavg1: prometheus.NewDesc(ns+"load_average_1", "System Load Average 1 Minute", labels, nil),
|
||||
Loadavg5: prometheus.NewDesc(ns+"load_average_5", "System Load Average 5 Minutes", labels, nil),
|
||||
Loadavg15: prometheus.NewDesc(ns+"load_average_15", "System Load Average 15 Minutes", labels, nil),
|
||||
MemUsed: prometheus.NewDesc(ns+"memory_used_bytes", "System Memory Used", labels, nil),
|
||||
MemTotal: prometheus.NewDesc(ns+"memory_installed_bytes", "System Installed Memory", labels, nil),
|
||||
MemBuffer: prometheus.NewDesc(ns+"memory_buffer_bytes", "System Memory Buffer", labels, nil),
|
||||
CPU: prometheus.NewDesc(ns+"cpu_utilization_ratio", "System CPU % Utilized", labels, nil),
|
||||
Mem: prometheus.NewDesc(ns+"memory_utilization_ratio", "System Memory % Utilized", labels, nil),
|
||||
Upgradeable: prometheus.NewDesc(ns+"upgradable", "Upgrade-able", labels, nil),
|
||||
TotalMaxPower: prometheus.NewDesc(ns+"max_power_total", "Total Max Power", labels, nil),
|
||||
OutletACPowerConsumption: prometheus.NewDesc(ns+"outlet_ac_power_consumption", "Outlet AC Power Consumption", labels, nil),
|
||||
PowerSource: prometheus.NewDesc(ns+"power_source", "Power Source", labels, nil),
|
||||
FanLevel: prometheus.NewDesc(ns+"fan_level", "Fan Level", labels, nil),
|
||||
TotalTxBytes: prometheus.NewDesc(ns+"transmit_bytes_total", "Total Transmitted Bytes", labels, nil),
|
||||
TotalRxBytes: prometheus.NewDesc(ns+"receive_bytes_total", "Total Received Bytes", labels, nil),
|
||||
TotalBytes: prometheus.NewDesc(ns+"bytes_total", "Total Bytes Transferred", labels, nil),
|
||||
BytesR: prometheus.NewDesc(ns+"rate_bytes", "Transfer Rate", labels, nil),
|
||||
BytesD: prometheus.NewDesc(ns+"d_bytes", "Total Bytes D???", labels, nil),
|
||||
TxBytesD: prometheus.NewDesc(ns+"d_tranmsit_bytes", "Transmit Bytes D???", labels, nil),
|
||||
RxBytesD: prometheus.NewDesc(ns+"d_receive_bytes", "Receive Bytes D???", labels, nil),
|
||||
Counter: prometheus.NewDesc(ns+"stations", "Number of Stations", append(labels, "station_type"), nil),
|
||||
Loadavg1: prometheus.NewDesc(ns+"load_average_1", "System Load Average 1 Minute", labels, nil),
|
||||
Loadavg5: prometheus.NewDesc(ns+"load_average_5", "System Load Average 5 Minutes", labels, nil),
|
||||
Loadavg15: prometheus.NewDesc(ns+"load_average_15", "System Load Average 15 Minutes", labels, nil),
|
||||
MemUsed: prometheus.NewDesc(ns+"memory_used_bytes", "System Memory Used", labels, nil),
|
||||
MemTotal: prometheus.NewDesc(ns+"memory_installed_bytes", "System Installed Memory", labels, nil),
|
||||
MemBuffer: prometheus.NewDesc(ns+"memory_buffer_bytes", "System Memory Buffer", labels, nil),
|
||||
CPU: prometheus.NewDesc(ns+"cpu_utilization_ratio", "System CPU % Utilized", labels, nil),
|
||||
Mem: prometheus.NewDesc(ns+"memory_utilization_ratio", "System Memory % Utilized", labels, nil),
|
||||
Upgradeable: prometheus.NewDesc(ns+"upgradable", "Upgrade-able", labels, nil),
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
Loading…
Reference in New Issue