mirror of
https://github.com/fumiama/terasu.git
synced 2026-07-01 18:20:24 +08:00
fix(dns): false-positive disable on deadline
This commit is contained in:
10
dns/dns.go
10
dns/dns.go
@@ -132,7 +132,9 @@ func (ds *DNSList) lookupHostDoH(ctx context.Context, host string) (hosts []stri
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
addr.disable(time.Hour) // no need to acquire write lock
|
if !errors.Is(err, context.DeadlineExceeded) && !errors.Is(err, context.Canceled) {
|
||||||
|
addr.disable(time.Hour) // no need to acquire write lock
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return nil // not found, fallback to ds.b
|
return nil // not found, fallback to ds.b
|
||||||
})
|
})
|
||||||
@@ -171,7 +173,7 @@ func (ds *DNSList) DialContext(ctx context.Context, dialer *net.Dialer, firstFra
|
|||||||
defer cancel()
|
defer cancel()
|
||||||
}
|
}
|
||||||
conn, err = dialer.DialContext(ctx, "tcp", addr.a)
|
conn, err = dialer.DialContext(ctx, "tcp", addr.a)
|
||||||
if err != nil {
|
if err != nil && !errors.Is(err, context.DeadlineExceeded) && !errors.Is(err, context.Canceled) {
|
||||||
addr.disable(time.Hour) // no need to acquire write lock
|
addr.disable(time.Hour) // no need to acquire write lock
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
@@ -181,7 +183,9 @@ func (ds *DNSList) DialContext(ctx context.Context, dialer *net.Dialer, firstFra
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
_ = tlsConn.Close()
|
_ = tlsConn.Close()
|
||||||
addr.disable(time.Hour) // no need to acquire write lock
|
if !errors.Is(err, context.DeadlineExceeded) && !errors.Is(err, context.Canceled) {
|
||||||
|
addr.disable(time.Hour) // no need to acquire write lock
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
})
|
})
|
||||||
|
|||||||
Reference in New Issue
Block a user