mirror of
https://gitclone.com/github.com/MetaCubeX/Clash.Meta
synced 2025-02-23 06:53:13 +08:00
chore: retry DNS over TCP when receive a truncated UDP response
https://github.com/MetaCubeX/mihomo/issues/1117
This commit is contained in:
parent
b3db113b1b
commit
c80dd5d738
@ -12,6 +12,7 @@ import (
|
|||||||
"github.com/metacubex/mihomo/component/dialer"
|
"github.com/metacubex/mihomo/component/dialer"
|
||||||
"github.com/metacubex/mihomo/component/resolver"
|
"github.com/metacubex/mihomo/component/resolver"
|
||||||
C "github.com/metacubex/mihomo/constant"
|
C "github.com/metacubex/mihomo/constant"
|
||||||
|
"github.com/metacubex/mihomo/log"
|
||||||
|
|
||||||
D "github.com/miekg/dns"
|
D "github.com/miekg/dns"
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/zhangyunhao116/fastrand"
|
||||||
@ -97,12 +98,22 @@ func (c *client) ExchangeContext(ctx context.Context, m *D.Msg) (*D.Msg, error)
|
|||||||
conn = tls.Client(conn, ca.GetGlobalTLSConfig(c.Client.TLSConfig))
|
conn = tls.Client(conn, ca.GetGlobalTLSConfig(c.Client.TLSConfig))
|
||||||
}
|
}
|
||||||
|
|
||||||
msg, _, err := c.Client.ExchangeWithConn(m, &D.Conn{
|
dConn := &D.Conn{
|
||||||
Conn: conn,
|
Conn: conn,
|
||||||
UDPSize: c.Client.UDPSize,
|
UDPSize: c.Client.UDPSize,
|
||||||
TsigSecret: c.Client.TsigSecret,
|
TsigSecret: c.Client.TsigSecret,
|
||||||
TsigProvider: c.Client.TsigProvider,
|
TsigProvider: c.Client.TsigProvider,
|
||||||
})
|
}
|
||||||
|
|
||||||
|
msg, _, err := c.Client.ExchangeWithConn(m, dConn)
|
||||||
|
|
||||||
|
// Resolvers MUST resend queries over TCP if they receive a truncated UDP response (with TC=1 set)!
|
||||||
|
if msg != nil && msg.Truncated && c.Client.Net == "" {
|
||||||
|
tcpClient := *c.Client // copy a client
|
||||||
|
tcpClient.Net = "tcp"
|
||||||
|
log.Debugln("[DNS] Truncated reply from %s:%s for %s over UDP, retrying over TCP", c.host, c.port, m.Question[0].String())
|
||||||
|
msg, _, err = tcpClient.ExchangeWithConn(m, dConn)
|
||||||
|
}
|
||||||
|
|
||||||
ch <- result{msg, err}
|
ch <- result{msg, err}
|
||||||
}()
|
}()
|
||||||
|
Loading…
Reference in New Issue
Block a user