From b48cf1bf65782c68600b00541113f90bb1aa88db Mon Sep 17 00:00:00 2001 From: Viktor Liu <17948409+lixmal@users.noreply.github.com> Date: Sat, 21 Dec 2024 15:56:52 +0100 Subject: [PATCH] [client] Reduce DNS handler chain lock contention (#3099) --- client/internal/dns/handler_chain.go | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/client/internal/dns/handler_chain.go b/client/internal/dns/handler_chain.go index c6ac3ebd6..9302d50b1 100644 --- a/client/internal/dns/handler_chain.go +++ b/client/internal/dns/handler_chain.go @@ -1,6 +1,7 @@ package dns import ( + "slices" "strings" "sync" @@ -161,16 +162,19 @@ func (c *HandlerChain) ServeDNS(w dns.ResponseWriter, r *dns.Msg) { log.Tracef("handling DNS request for domain=%s", qname) c.mu.RLock() - defer c.mu.RUnlock() + handlers := slices.Clone(c.handlers) + c.mu.RUnlock() - log.Tracef("current handlers (%d):", len(c.handlers)) - for _, h := range c.handlers { - log.Tracef(" - pattern: domain=%s original: domain=%s wildcard=%v priority=%d", - h.Pattern, h.OrigPattern, h.IsWildcard, h.Priority) + if log.IsLevelEnabled(log.TraceLevel) { + log.Tracef("current handlers (%d):", len(handlers)) + for _, h := range handlers { + log.Tracef(" - pattern: domain=%s original: domain=%s wildcard=%v priority=%d", + h.Pattern, h.OrigPattern, h.IsWildcard, h.Priority) + } } // Try handlers in priority order - for _, entry := range c.handlers { + for _, entry := range handlers { var matched bool switch { case entry.Pattern == ".":