mirror of
https://github.com/prometheus/node_exporter.git
synced 2025-08-20 18:33:52 -07:00
Add few fields for freebsd network status.
Signed-off-by: K Rin <rin@sandb0x.tw>
This commit is contained in:
parent
e768aad83d
commit
ba3637b2df
|
@ -17,7 +17,6 @@
|
||||||
package collector
|
package collector
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"errors"
|
|
||||||
"fmt"
|
"fmt"
|
||||||
"log/slog"
|
"log/slog"
|
||||||
"unsafe"
|
"unsafe"
|
||||||
|
@ -33,21 +32,68 @@ import (
|
||||||
#include <netinet/tcp.h>
|
#include <netinet/tcp.h>
|
||||||
#include <netinet/tcp_var.h>
|
#include <netinet/tcp_var.h>
|
||||||
#include <netinet/udp.h>
|
#include <netinet/udp.h>
|
||||||
|
#include <netinet/udp_var.h>
|
||||||
*/
|
*/
|
||||||
import "C"
|
import "C"
|
||||||
|
|
||||||
var (
|
var (
|
||||||
|
// TCP metrics
|
||||||
bsdNetstatTcpSendPacketsTotal = prometheus.NewDesc(
|
bsdNetstatTcpSendPacketsTotal = prometheus.NewDesc(
|
||||||
prometheus.BuildFQName(namespace, "netstat", "tcp_transmit_packets_total"),
|
prometheus.BuildFQName(namespace, "netstat", "tcp_transmit_packets_total"),
|
||||||
"TCP packets sent",
|
"TCP packets sent",
|
||||||
nil, nil,
|
nil, nil,
|
||||||
)
|
)
|
||||||
|
|
||||||
bsdNetstatTcpRecvPacketsTotal = prometheus.NewDesc(
|
bsdNetstatTcpRecvPacketsTotal = prometheus.NewDesc(
|
||||||
prometheus.BuildFQName(namespace, "netstat", "tcp_receive_packets_total"),
|
prometheus.BuildFQName(namespace, "netstat", "tcp_receive_packets_total"),
|
||||||
"TCP packets received",
|
"TCP packets received",
|
||||||
nil, nil,
|
nil, nil,
|
||||||
)
|
)
|
||||||
|
bsdNetstatTcpConnectionAttempts = prometheus.NewDesc(
|
||||||
|
prometheus.BuildFQName(namespace, "netstat", "tcp_connection_attempts_total"),
|
||||||
|
"Number of times TCP connections have been initiated",
|
||||||
|
nil, nil,
|
||||||
|
)
|
||||||
|
bsdNetstatTcpConnectionAccepts = prometheus.NewDesc(
|
||||||
|
prometheus.BuildFQName(namespace, "netstat", "tcp_connection_accepts_total"),
|
||||||
|
"Number of times TCP connections have made it to established state",
|
||||||
|
nil, nil,
|
||||||
|
)
|
||||||
|
bsdNetstatTcpConnectionDrops = prometheus.NewDesc(
|
||||||
|
prometheus.BuildFQName(namespace, "netstat", "tcp_connection_drops_total"),
|
||||||
|
"Number of dropped TCP connections",
|
||||||
|
nil, nil,
|
||||||
|
)
|
||||||
|
bsdNetstatTcpRetransmitPackets = prometheus.NewDesc(
|
||||||
|
prometheus.BuildFQName(namespace, "netstat", "tcp_retransmit_packets_total"),
|
||||||
|
"Number of TCP data packets retransmitted",
|
||||||
|
nil, nil,
|
||||||
|
)
|
||||||
|
// UDP metrics
|
||||||
|
bsdNetstatUdpSendPacketsTotal = prometheus.NewDesc(
|
||||||
|
prometheus.BuildFQName(namespace, "netstat", "udp_transmit_packets_total"),
|
||||||
|
"UDP packets sent",
|
||||||
|
nil, nil,
|
||||||
|
)
|
||||||
|
bsdNetstatUdpRecvPacketsTotal = prometheus.NewDesc(
|
||||||
|
prometheus.BuildFQName(namespace, "netstat", "udp_receive_packets_total"),
|
||||||
|
"UDP packets received",
|
||||||
|
nil, nil,
|
||||||
|
)
|
||||||
|
bsdNetstatUdpHeaderDrops = prometheus.NewDesc(
|
||||||
|
prometheus.BuildFQName(namespace, "netstat", "udp_header_drops_total"),
|
||||||
|
"Number of UDP packets dropped due to invalid header",
|
||||||
|
nil, nil,
|
||||||
|
)
|
||||||
|
bsdNetstatUdpBadChecksum = prometheus.NewDesc(
|
||||||
|
prometheus.BuildFQName(namespace, "netstat", "udp_bad_checksum_total"),
|
||||||
|
"Number of UDP packets dropped due to bad checksum",
|
||||||
|
nil, nil,
|
||||||
|
)
|
||||||
|
bsdNetstatUdpNoPort = prometheus.NewDesc(
|
||||||
|
prometheus.BuildFQName(namespace, "netstat", "udp_no_port_total"),
|
||||||
|
"Number of UDP packets to port with no listener",
|
||||||
|
nil, nil,
|
||||||
|
)
|
||||||
)
|
)
|
||||||
|
|
||||||
type netStatCollector struct {
|
type netStatCollector struct {
|
||||||
|
@ -76,18 +122,16 @@ func getData(queryString string) ([]byte, error) {
|
||||||
fmt.Println("Error:", err)
|
fmt.Println("Error:", err)
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
if len(data) < int(unsafe.Sizeof(C.struct_tcpstat{})) {
|
|
||||||
return nil, errors.New("Data Size mismatch")
|
|
||||||
}
|
|
||||||
return data, nil
|
return data, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *netStatCollector) Update(ch chan<- prometheus.Metric) error {
|
func (c *netStatCollector) Update(ch chan<- prometheus.Metric) error {
|
||||||
|
|
||||||
tcpData, err := getData("net.inet.tcp.stats")
|
tcpData, err := getData("net.inet.tcp.stats")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return fmt.Errorf("failed to get TCP stats: %w", err)
|
||||||
|
}
|
||||||
|
if len(tcpData) < int(unsafe.Sizeof(C.struct_tcpstat{})) {
|
||||||
|
return fmt.Errorf("TCP data size mismatch: got %d, want >= %d", len(tcpData), unsafe.Sizeof(C.struct_tcpstat{}))
|
||||||
}
|
}
|
||||||
|
|
||||||
tcpStats := *(*C.struct_tcpstat)(unsafe.Pointer(&tcpData[0]))
|
tcpStats := *(*C.struct_tcpstat)(unsafe.Pointer(&tcpData[0]))
|
||||||
|
@ -97,12 +141,67 @@ func (c *netStatCollector) Update(ch chan<- prometheus.Metric) error {
|
||||||
prometheus.CounterValue,
|
prometheus.CounterValue,
|
||||||
float64(tcpStats.tcps_sndtotal),
|
float64(tcpStats.tcps_sndtotal),
|
||||||
)
|
)
|
||||||
|
|
||||||
ch <- prometheus.MustNewConstMetric(
|
ch <- prometheus.MustNewConstMetric(
|
||||||
bsdNetstatTcpRecvPacketsTotal,
|
bsdNetstatTcpRecvPacketsTotal,
|
||||||
prometheus.CounterValue,
|
prometheus.CounterValue,
|
||||||
float64(tcpStats.tcps_rcvtotal),
|
float64(tcpStats.tcps_rcvtotal),
|
||||||
)
|
)
|
||||||
|
ch <- prometheus.MustNewConstMetric(
|
||||||
|
bsdNetstatTcpConnectionAttempts,
|
||||||
|
prometheus.CounterValue,
|
||||||
|
float64(tcpStats.tcps_connattempt),
|
||||||
|
)
|
||||||
|
ch <- prometheus.MustNewConstMetric(
|
||||||
|
bsdNetstatTcpConnectionAccepts,
|
||||||
|
prometheus.CounterValue,
|
||||||
|
float64(tcpStats.tcps_accepts),
|
||||||
|
)
|
||||||
|
ch <- prometheus.MustNewConstMetric(
|
||||||
|
bsdNetstatTcpConnectionDrops,
|
||||||
|
prometheus.CounterValue,
|
||||||
|
float64(tcpStats.tcps_drops),
|
||||||
|
)
|
||||||
|
ch <- prometheus.MustNewConstMetric(
|
||||||
|
bsdNetstatTcpRetransmitPackets,
|
||||||
|
prometheus.CounterValue,
|
||||||
|
float64(tcpStats.tcps_sndrexmitpack),
|
||||||
|
)
|
||||||
|
|
||||||
|
udpData, err := getData("net.inet.udp.stats")
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("failed to get UDP stats: %w", err)
|
||||||
|
}
|
||||||
|
if len(udpData) < int(unsafe.Sizeof(C.struct_udpstat{})) {
|
||||||
|
return fmt.Errorf("UDP data size mismatch: got %d, want >= %d", len(udpData), unsafe.Sizeof(C.struct_udpstat{}))
|
||||||
|
}
|
||||||
|
|
||||||
|
udpStats := *(*C.struct_udpstat)(unsafe.Pointer(&udpData[0]))
|
||||||
|
|
||||||
|
ch <- prometheus.MustNewConstMetric(
|
||||||
|
bsdNetstatUdpSendPacketsTotal,
|
||||||
|
prometheus.CounterValue,
|
||||||
|
float64(udpStats.udps_opackets),
|
||||||
|
)
|
||||||
|
ch <- prometheus.MustNewConstMetric(
|
||||||
|
bsdNetstatUdpRecvPacketsTotal,
|
||||||
|
prometheus.CounterValue,
|
||||||
|
float64(udpStats.udps_ipackets),
|
||||||
|
)
|
||||||
|
ch <- prometheus.MustNewConstMetric(
|
||||||
|
bsdNetstatUdpHeaderDrops,
|
||||||
|
prometheus.CounterValue,
|
||||||
|
float64(udpStats.udps_hdrops),
|
||||||
|
)
|
||||||
|
ch <- prometheus.MustNewConstMetric(
|
||||||
|
bsdNetstatUdpBadChecksum,
|
||||||
|
prometheus.CounterValue,
|
||||||
|
float64(udpStats.udps_badsum),
|
||||||
|
)
|
||||||
|
ch <- prometheus.MustNewConstMetric(
|
||||||
|
bsdNetstatUdpNoPort,
|
||||||
|
prometheus.CounterValue,
|
||||||
|
float64(udpStats.udps_noport),
|
||||||
|
)
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue