mirror of
				https://github.com/coredns/coredns.git
				synced 2025-10-25 22:32:05 +02:00 
			
		
		
		
	* healthchecks: check on every 3rd failure Check on every third failure and some cleanups to make this possible. A failed healthcheck will never increase Fails, a successfull healthceck will reset Fails to 0. This is a chance this counter now drops below 0, making the upstream super? healthy. This removes the okUntil smartness and condences everything back to 1 metrics: Fails; so it's simpler in that regard. Timout errors are *not* attributed to the local upstream, and don't get counted into the Fails anymore. Meaning the 'dig any isc.org' won't kill your upstream. Added extra test the see if the Fails counter gets reset after 3 failed connection. There is still a disconnect beween HTTP healthceck working the proxy (or lookup) not being able to connect to the upstream. * Fix tests
		
			
				
	
	
		
			67 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			67 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package proxy
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"io/ioutil"
 | |
| 	"log"
 | |
| 	"net/http"
 | |
| 	"net/http/httptest"
 | |
| 	"strings"
 | |
| 	"sync/atomic"
 | |
| 	"testing"
 | |
| 	"time"
 | |
| 
 | |
| 	"github.com/coredns/coredns/plugin/test"
 | |
| 	"github.com/coredns/coredns/request"
 | |
| 
 | |
| 	"github.com/mholt/caddy/caddyfile"
 | |
| 	"github.com/miekg/dns"
 | |
| )
 | |
| 
 | |
| func init() {
 | |
| 	log.SetOutput(ioutil.Discard)
 | |
| }
 | |
| 
 | |
| func TestUnhealthy(t *testing.T) {
 | |
| 	// High HC interval, we want to test the HC after failed queries.
 | |
| 	config := "proxy . %s {\n health_check /healthcheck:%s 10s \nfail_timeout 100ms\n}"
 | |
| 
 | |
| 	backend := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
 | |
| 		r.Body.Close()
 | |
| 		w.Write([]byte("OK"))
 | |
| 	}))
 | |
| 	defer backend.Close()
 | |
| 
 | |
| 	port := backend.URL[17:] // Remove all crap up to the port
 | |
| 	back := backend.URL[7:]  // Remove http://
 | |
| 
 | |
| 	c := caddyfile.NewDispenser("testfile", strings.NewReader(fmt.Sprintf(config, back, port)))
 | |
| 	upstreams, err := NewStaticUpstreams(&c)
 | |
| 	if err != nil {
 | |
| 		t.Errorf("Expected no error. Got: %s", err)
 | |
| 	}
 | |
| 	p := &Proxy{Upstreams: &upstreams}
 | |
| 	m := new(dns.Msg)
 | |
| 	m.SetQuestion("example.org.", dns.TypeA)
 | |
| 	state := request.Request{W: &test.ResponseWriter{}, Req: m}
 | |
| 
 | |
| 	// Should all fail.
 | |
| 	for j := 0; j < failureCheck; j++ {
 | |
| 		if _, err := p.Forward(state); err == nil {
 | |
| 			t.Errorf("Expected error. Got: nil")
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	fails := atomic.LoadInt32(&upstreams[0].(*staticUpstream).Hosts[0].Fails)
 | |
| 	if fails != 3 {
 | |
| 		t.Errorf("Expected %d fails, got %d", 3, fails)
 | |
| 	}
 | |
| 	// HC should be kicked off, and reset the counter to 0
 | |
| 	i := 0
 | |
| 	for fails != 0 {
 | |
| 		fails = atomic.LoadInt32(&upstreams[0].(*staticUpstream).Hosts[0].Fails)
 | |
| 		time.Sleep(100 * time.Microsecond)
 | |
| 		i++
 | |
| 	}
 | |
| }
 |