From 1847ef6bd31ecd38fe5d19e54c47a812cb2ed303 Mon Sep 17 00:00:00 2001 From: Tom Thorogood Date: Sun, 14 Oct 2018 04:26:42 +1030 Subject: [PATCH] plugin/file: Fix memory leak in Parse (#2194) For zone files with more than 10,000 records, the goroutines and memory pinned by dns.ParseZone won't be released unless the tokens chan is drained. As Parse is called by (*Zone).Reload very frequently, this causes memory leaks and OOM conditions. Updates miekg/dns#786 --- plugin/file/file.go | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/plugin/file/file.go b/plugin/file/file.go index 5c13042cb..2711282eb 100644 --- a/plugin/file/file.go +++ b/plugin/file/file.go @@ -121,6 +121,12 @@ func (s *serialErr) Error() string { // it returns an error indicating nothing was read. func Parse(f io.Reader, origin, fileName string, serial int64) (*Zone, error) { tokens := dns.ParseZone(f, dns.Fqdn(origin), fileName) + defer func() { + // Drain the tokens chan so that large zone files won't + // leak goroutines and memory. + for range tokens { + } + }() z := NewZone(origin, fileName) seenSOA := false for x := range tokens {