Allow checking multiple SOAs from different servers
This commit is contained in:
parent
3a7108f620
commit
0fc7986bd0
35
dns.go
35
dns.go
@ -9,7 +9,7 @@ package main
|
|||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"errors"
|
"errors"
|
||||||
// "fmt"
|
// "fmt"
|
||||||
dns "github.com/miekg/dns"
|
dns "github.com/miekg/dns"
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
log "github.com/sirupsen/logrus"
|
log "github.com/sirupsen/logrus"
|
||||||
@ -143,6 +143,11 @@ func (m *DNSMetrics) Collect() {
|
|||||||
|
|
||||||
now := uint64(time.Now().Unix())
|
now := uint64(time.Now().Unix())
|
||||||
|
|
||||||
|
// icky icky icky
|
||||||
|
masters := make([]uint64, 2)
|
||||||
|
masters[0] = dns_servers[0].soa
|
||||||
|
masters[1] = dns_servers[6].soa
|
||||||
|
|
||||||
// go through each server in turn
|
// go through each server in turn
|
||||||
for ix, server := range dns_servers {
|
for ix, server := range dns_servers {
|
||||||
|
|
||||||
@ -161,12 +166,18 @@ func (m *DNSMetrics) Collect() {
|
|||||||
// didn't get a result, server issue
|
// didn't get a result, server issue
|
||||||
valid = 2
|
valid = 2
|
||||||
} else {
|
} else {
|
||||||
if server.soa != dns_servers[0].soa {
|
// check if the SOA matches any defined master SOA
|
||||||
// SOA didn't match
|
|
||||||
valid = 1
|
// assume not
|
||||||
} else {
|
valid = 1
|
||||||
valid = 0
|
for _, soa := range masters {
|
||||||
|
if server.soa == soa {
|
||||||
|
// match was found
|
||||||
|
valid = 0
|
||||||
|
break
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// before setting whether the server is valid, calculate the stime
|
// before setting whether the server is valid, calculate the stime
|
||||||
@ -280,8 +291,16 @@ func (m *DNSCommitMetrics) Collect() {
|
|||||||
m.mismatch = true
|
m.mismatch = true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
since := now.Sub(m.since).Seconds()
|
||||||
|
|
||||||
|
log.WithFields(log.Fields{
|
||||||
|
"master": mc,
|
||||||
|
"explorer": ec,
|
||||||
|
"since": since,
|
||||||
|
}).Warn("DNS Commit Mismatch")
|
||||||
|
|
||||||
// set the metric to be the interval since last good match
|
// set the metric to be the interval since last good match
|
||||||
m.match.With(m.labelInvalid).Set(float64(now.Sub(m.since).Seconds()))
|
m.match.With(m.labelInvalid).Set(float64(since))
|
||||||
}
|
}
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
@ -326,7 +345,7 @@ func (m *DNSCommitMetrics) FetchExplorerCommit() (string, error) {
|
|||||||
|
|
||||||
func (m *DNSCommitMetrics) FetchMasterCommit() (string, error) {
|
func (m *DNSCommitMetrics) FetchMasterCommit() (string, error) {
|
||||||
|
|
||||||
response, err := http.Get("http://[2a0c:3800:1:1011:5054:ff:fe87:ea39]:8080/api/git-db-state")
|
response, err := http.Get("http://[fd42:180:3de0:10:5054:ff:fe87:ea39]:8080/api/git-db-state")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.WithFields(log.Fields{
|
log.WithFields(log.Fields{
|
||||||
"error": err,
|
"error": err,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user