dhcp4d: export number of non-expired DHCP leases
This commit is contained in:
parent
4288adec69
commit
d9f5d95812
@ -19,19 +19,45 @@ import (
|
|||||||
"encoding/json"
|
"encoding/json"
|
||||||
"flag"
|
"flag"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
|
"net"
|
||||||
|
"net/http"
|
||||||
"os"
|
"os"
|
||||||
|
"os/signal"
|
||||||
"syscall"
|
"syscall"
|
||||||
|
"time"
|
||||||
|
|
||||||
"github.com/rtr7/router7/internal/dhcp4d"
|
"github.com/gokrazy/gokrazy"
|
||||||
"github.com/rtr7/router7/internal/notify"
|
|
||||||
"github.com/rtr7/router7/internal/teelogger"
|
|
||||||
|
|
||||||
"github.com/krolaw/dhcp4"
|
"github.com/krolaw/dhcp4"
|
||||||
"github.com/krolaw/dhcp4/conn"
|
"github.com/krolaw/dhcp4/conn"
|
||||||
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
|
"github.com/prometheus/client_golang/prometheus/promauto"
|
||||||
|
"github.com/prometheus/client_golang/prometheus/promhttp"
|
||||||
|
|
||||||
|
"github.com/rtr7/router7/internal/dhcp4d"
|
||||||
|
"github.com/rtr7/router7/internal/multilisten"
|
||||||
|
"github.com/rtr7/router7/internal/notify"
|
||||||
|
"github.com/rtr7/router7/internal/teelogger"
|
||||||
)
|
)
|
||||||
|
|
||||||
var log = teelogger.NewConsole()
|
var log = teelogger.NewConsole()
|
||||||
|
|
||||||
|
var nonExpiredLeases = promauto.NewGauge(prometheus.GaugeOpts{
|
||||||
|
Name: "non_expired_leases",
|
||||||
|
Help: "Number of non-expired DHCP leases",
|
||||||
|
})
|
||||||
|
|
||||||
|
func updateNonExpired(leases []*dhcp4d.Lease) {
|
||||||
|
now := time.Now()
|
||||||
|
nonExpired := 0
|
||||||
|
for _, l := range leases {
|
||||||
|
if l.Expired(now) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
nonExpired++
|
||||||
|
}
|
||||||
|
nonExpiredLeases.Set(float64(nonExpired))
|
||||||
|
}
|
||||||
|
|
||||||
func loadLeases(h *dhcp4d.Handler, fn string) error {
|
func loadLeases(h *dhcp4d.Handler, fn string) error {
|
||||||
b, err := ioutil.ReadFile(fn)
|
b, err := ioutil.ReadFile(fn)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -45,10 +71,42 @@ func loadLeases(h *dhcp4d.Handler, fn string) error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
h.SetLeases(leases)
|
h.SetLeases(leases)
|
||||||
|
updateNonExpired(leases)
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
var httpListeners = multilisten.NewPool()
|
||||||
|
|
||||||
|
func updateListeners() error {
|
||||||
|
hosts, err := gokrazy.PrivateInterfaceAddrs()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
if net1, err := multilisten.IPv6Net1("/perm"); err == nil {
|
||||||
|
hosts = append(hosts, net1)
|
||||||
|
}
|
||||||
|
|
||||||
|
httpListeners.ListenAndServe(hosts, func(host string) multilisten.Listener {
|
||||||
|
return &http.Server{Addr: net.JoinHostPort(host, "8067")}
|
||||||
|
})
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func logic() error {
|
func logic() error {
|
||||||
|
http.Handle("/metrics", promhttp.Handler())
|
||||||
|
if err := updateListeners(); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
go func() {
|
||||||
|
ch := make(chan os.Signal, 1)
|
||||||
|
signal.Notify(ch, syscall.SIGUSR1)
|
||||||
|
for range ch {
|
||||||
|
if err := updateListeners(); err != nil {
|
||||||
|
log.Printf("updateListeners: %v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
|
||||||
if err := os.MkdirAll("/perm/dhcp4d", 0755); err != nil {
|
if err := os.MkdirAll("/perm/dhcp4d", 0755); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -71,6 +129,7 @@ func logic() error {
|
|||||||
if err := ioutil.WriteFile("/perm/dhcp4d/leases.json", b, 0644); err != nil {
|
if err := ioutil.WriteFile("/perm/dhcp4d/leases.json", b, 0644); err != nil {
|
||||||
errs <- err
|
errs <- err
|
||||||
}
|
}
|
||||||
|
updateNonExpired(leases)
|
||||||
if err := notify.Process("/user/dnsd", syscall.SIGUSR1); err != nil {
|
if err := notify.Process("/user/dnsd", syscall.SIGUSR1); err != nil {
|
||||||
log.Printf("notifying dnsd: %v", err)
|
log.Printf("notifying dnsd: %v", err)
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user