aboutsummaryrefslogtreecommitdiff
path: root/middleware/erratic/erratic.go
diff options
context:
space:
mode:
authorGravatar Miek Gieben <miek@miek.nl> 2017-04-13 16:26:17 +0100
committerGravatar GitHub <noreply@github.com> 2017-04-13 16:26:17 +0100
commita83d97a5c446481da3b9efc8f017e6a6ea34b7b0 (patch)
treebb8c23fb67f57982428cef5e990d6f1c97a349ad /middleware/erratic/erratic.go
parentacbf522cebdcd53c26d153c1d9267d709ba75f64 (diff)
downloadcoredns-a83d97a5c446481da3b9efc8f017e6a6ea34b7b0.tar.gz
coredns-a83d97a5c446481da3b9efc8f017e6a6ea34b7b0.tar.zst
coredns-a83d97a5c446481da3b9efc8f017e6a6ea34b7b0.zip
middleware/erratic: add delaying queries (#614)
* middleware/erratic: add delying queries * Dont println
Diffstat (limited to 'middleware/erratic/erratic.go')
-rw-r--r--middleware/erratic/erratic.go30
1 files changed, 23 insertions, 7 deletions
diff --git a/middleware/erratic/erratic.go b/middleware/erratic/erratic.go
index a3fbb2e8e..1f663a558 100644
--- a/middleware/erratic/erratic.go
+++ b/middleware/erratic/erratic.go
@@ -3,6 +3,7 @@ package erratic
import (
"sync/atomic"
+ "time"
"github.com/coredns/coredns/request"
@@ -12,7 +13,10 @@ import (
// Erratic is a middleware that returns erratic repsonses to each client.
type Erratic struct {
- amount uint64
+ drop uint64
+
+ delay uint64
+ duration time.Duration
q uint64 // counter of queries
}
@@ -20,16 +24,21 @@ type Erratic struct {
// ServeDNS implements the middleware.Handler interface.
func (e *Erratic) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dns.Msg) (int, error) {
state := request.Request{W: w, Req: r}
-
drop := false
- if e.amount > 0 {
- queryNr := atomic.LoadUint64(&e.q)
+ delay := false
- if queryNr%e.amount == 0 {
+ queryNr := atomic.LoadUint64(&e.q)
+ atomic.AddUint64(&e.q, 1)
+
+ if e.drop > 0 {
+ if queryNr%e.drop == 0 {
drop = true
}
-
- atomic.AddUint64(&e.q, 1)
+ }
+ if e.delay > 0 {
+ if queryNr%e.delay == 0 {
+ delay = true
+ }
}
m := new(dns.Msg)
@@ -50,6 +59,9 @@ func (e *Erratic) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dns.Msg
m.Answer = append(m.Answer, &rr)
default:
if !drop {
+ if delay {
+ time.Sleep(e.duration)
+ }
// coredns will return error.
return dns.RcodeServerFailure, nil
}
@@ -59,6 +71,10 @@ func (e *Erratic) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dns.Msg
return 0, nil
}
+ if delay {
+ time.Sleep(e.duration)
+ }
+
state.SizeAndDo(m)
w.WriteMsg(m)