Package io.netty.resolver.dns
Class DnsNameResolver
java.lang.Object
io.netty.resolver.SimpleNameResolver<InetAddress>
io.netty.resolver.InetNameResolver
io.netty.resolver.dns.DnsNameResolver
- All Implemented Interfaces:
NameResolver<InetAddress>,Closeable,AutoCloseable
A DNS-based
InetNameResolver.-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionprivate static final classprivate static final classprivate static interfaceprivate static final class -
Field Summary
FieldsModifier and TypeFieldDescriptionprivate final AuthoritativeDnsServerCacheprivate final DnsCnameCacheprivate final booleanprivate static final DatagramDnsResponseDecoderprivate static final DatagramDnsQueryEncoderprivate final booleanprivate static final UnixResolverOptions(package private) static final ResolvedAddressTypes(package private) static final String[]static final AttributeKey<Boolean> An attribute used to mark all channels created by theDnsNameResolver.private final DnsQueryLifecycleObserverFactoryprivate final DnsServerAddressStreamProviderprivate static final DnsRecord[]private final HostsFileEntriesResolverprivate final Map<String, Future<List<InetAddress>>> private static final InternetProtocolFamily[]private static final DnsRecordType[]private static final InternetProtocolFamily[]private static final DnsRecordType[]private static final InternetProtocolFamily[]private static final DnsRecordType[]private static final InternetProtocolFamily[]private static final DnsRecordType[]private static final Stringprivate static final InetAddressprivate static final InternalLoggerprivate final intprivate final intprivate final intprivate final Comparator<InetSocketAddress> private final intprivate static final ChannelHandlerprivate final booleanprivate final InternetProtocolFamilyprivate final DnsQueryContextManagerManages theDnsQueryContexts in progress and their query IDs.private final DnsServerAddressStreamprivate final longprivate final booleanprivate final DnsCacheCache fordoResolve(String, Promise)anddoResolveAll(String, Promise).private final DnsNameResolver.DnsResolveChannelProviderprivate final ResolvedAddressTypesprivate final InternetProtocolFamily[]private final DnsRecordType[]private final booleanprivate final String[]private final Bootstrapprivate final booleanprivate final booleanprivate static final String -
Constructor Summary
ConstructorsConstructorDescriptionDnsNameResolver(EventLoop eventLoop, ChannelFactory<? extends DatagramChannel> channelFactory, ChannelFactory<? extends SocketChannel> socketChannelFactory, boolean retryWithTcpOnTimeout, DnsCache resolveCache, DnsCnameCache cnameCache, AuthoritativeDnsServerCache authoritativeDnsServerCache, SocketAddress localAddress, DnsQueryLifecycleObserverFactory dnsQueryLifecycleObserverFactory, long queryTimeoutMillis, ResolvedAddressTypes resolvedAddressTypes, boolean recursionDesired, int maxQueriesPerResolve, boolean traceEnabled, int maxPayloadSize, boolean optResourceEnabled, HostsFileEntriesResolver hostsFileEntriesResolver, DnsServerAddressStreamProvider dnsServerAddressStreamProvider, DnsServerAddressStream queryDnsServerAddressStream, String[] searchDomains, int ndots, boolean decodeIdn, boolean completeOncePreferredResolved, int maxNumConsolidation, DnsNameResolverChannelStrategy datagramChannelStrategy) DnsNameResolver(EventLoop eventLoop, ChannelFactory<? extends DatagramChannel> channelFactory, DnsCache resolveCache, AuthoritativeDnsServerCache authoritativeDnsServerCache, DnsQueryLifecycleObserverFactory dnsQueryLifecycleObserverFactory, long queryTimeoutMillis, ResolvedAddressTypes resolvedAddressTypes, boolean recursionDesired, int maxQueriesPerResolve, boolean traceEnabled, int maxPayloadSize, boolean optResourceEnabled, HostsFileEntriesResolver hostsFileEntriesResolver, DnsServerAddressStreamProvider dnsServerAddressStreamProvider, String[] searchDomains, int ndots, boolean decodeIdn) Deprecated.DnsNameResolver(EventLoop eventLoop, ChannelFactory<? extends DatagramChannel> channelFactory, DnsCache resolveCache, DnsCache authoritativeDnsServerCache, DnsQueryLifecycleObserverFactory dnsQueryLifecycleObserverFactory, long queryTimeoutMillis, ResolvedAddressTypes resolvedAddressTypes, boolean recursionDesired, int maxQueriesPerResolve, boolean traceEnabled, int maxPayloadSize, boolean optResourceEnabled, HostsFileEntriesResolver hostsFileEntriesResolver, DnsServerAddressStreamProvider dnsServerAddressStreamProvider, String[] searchDomains, int ndots, boolean decodeIdn) Deprecated. -
Method Summary
Modifier and TypeMethodDescriptionprivate static booleanReturns the cache used for authoritative DNS servers for a domain.private static Promise<AddressedEnvelope<DnsResponse, InetSocketAddress>> voidclose()Closes the internal datagram channel used for sending and receiving DNS messages, and clears all DNS resource records from the cache.Returns theDnsCnameCache.(package private) final DnsQueryLifecycleObserverFactory(package private) final Future<AddressedEnvelope<DnsResponse, InetSocketAddress>> doQuery(Channel channel, InetSocketAddress nameServerAddr, DnsQuestion question, DnsQueryLifecycleObserver queryLifecycleObserver, DnsRecord[] additionals, boolean flush, Promise<AddressedEnvelope<? extends DnsResponse, InetSocketAddress>> promise) protected voiddoResolve(String inetHost, DnsRecord[] additionals, Promise<InetAddress> promise, DnsCache resolveCache) Hook designed for extensibility so one can pass a different cache on each resolution attempt instead of using the global one.protected voiddoResolve(String inetHost, Promise<InetAddress> promise) Invoked bySimpleNameResolver.resolve(String)to perform the actual name resolution.protected voiddoResolveAll(String inetHost, DnsRecord[] additionals, Promise<List<InetAddress>> promise, DnsCache resolveCache) Hook designed for extensibility so one can pass a different cache on each resolution attempt instead of using the global one.protected voiddoResolveAll(String inetHost, Promise<List<InetAddress>> promise) Invoked bySimpleNameResolver.resolveAll(String)to perform the actual name resolution.(package private) static booleandoResolveAllCached(String hostname, DnsRecord[] additionals, Promise<List<InetAddress>> promise, DnsCache resolveCache, String[] searchDomains, int ndots, InternetProtocolFamily[] resolvedInternetProtocolFamilies) private voiddoResolveAllNow(ChannelFuture f, String hostname, DnsRecord[] additionals, Promise<List<InetAddress>> promise, DnsCache resolveCache) private voiddoResolveAllUncached(Channel channel, String hostname, DnsRecord[] additionals, Promise<?> originalPromise, Promise<List<InetAddress>> promise, DnsCache resolveCache, boolean completeEarlyIfPossible) private voiddoResolveAllUncached0(Channel channel, String hostname, DnsRecord[] additionals, Promise<?> originalPromise, Promise<List<InetAddress>> promise, DnsCache resolveCache, boolean completeEarlyIfPossible) private booleandoResolveCached(String hostname, DnsRecord[] additionals, Promise<InetAddress> promise, DnsCache resolveCache) private voiddoResolveNow(ChannelFuture f, String hostname, DnsRecord[] additionals, Promise<InetAddress> promise, DnsCache resolveCache) private voiddoResolveUncached(Channel channel, String hostname, DnsRecord[] additionals, Promise<InetAddress> promise, DnsCache resolveCache, boolean completeEarlyIfPossible) protected EventLoopexecutor()Returns theEventExecutorwhich is used to notify the listeners of theFuturereturned bySimpleNameResolver.resolve(String).private static booleanhasEntries(List<? extends DnsCacheEntry> cachedEntries) private static StringReturns the component that tries to resolve hostnames against the hosts file prior to asking to remotes DNS servers.(package private) final booleanprivate static booleanisLocalWindowsHost(String hostname) Checks whether the given hostname is the localhost/host (computer) name on Windows OS.booleanReturns the automatic inclusion of a optional records that tries to give the remote DNS server a hint about how much data the resolver can read per response is enabled.booleanReturnstrueif and only if this resolver sends a DNS query with the RD (recursion desired) flag set.static booleanisTimeoutError(Throwable cause) Returnstrueif theThrowablewas caused by an timeout.static booleanReturnstrueif theThrowablewas caused by an timeout or transport error.private InetAddressintReturns the capacity of the datagram packet buffer (in bytes).intReturns the maximum allowed number of DNS queries to send when resolving a host name.(package private) final intndots()(package private) final DnsServerAddressStreamnewNameServerAddressStream(String hostname) private static DnsNameResolver.DnsResolveChannelProvidernewProvider(DnsNameResolverChannelStrategy channelStrategy, Bootstrap bootstrap, SocketAddress localAddress) protected DnsServerAddressStreamnewRedirectDnsServerStream(String hostname, List<InetSocketAddress> nameservers) Creates a newDnsServerAddressStreamto following a redirected DNS query.(package private) InetSocketAddressnewRedirectServerAddress(InetAddress server) private InetSocketAddress(package private) final InternetProtocolFamily(package private) static InternetProtocolFamilypreferredAddressType(ResolvedAddressTypes resolvedAddressTypes) query(DnsQuestion question) Sends a DNS query with the specified question.query(DnsQuestion question, Promise<AddressedEnvelope<? extends DnsResponse, InetSocketAddress>> promise) Sends a DNS query with the specified question.query(DnsQuestion question, Iterable<DnsRecord> additionals) Sends a DNS query with the specified question with additional records.query(InetSocketAddress nameServerAddr, DnsQuestion question) Sends a DNS query with the specified question using the specified name server list.query(InetSocketAddress nameServerAddr, DnsQuestion question, Promise<AddressedEnvelope<? extends DnsResponse, InetSocketAddress>> promise) Sends a DNS query with the specified question using the specified name server list.query(InetSocketAddress nameServerAddr, DnsQuestion question, Iterable<DnsRecord> additionals) Sends a DNS query with the specified question with additional records using the specified name server list.query(InetSocketAddress nameServerAddr, DnsQuestion question, Iterable<DnsRecord> additionals, Promise<AddressedEnvelope<? extends DnsResponse, InetSocketAddress>> promise) Sends a DNS query with the specified question with additional records using the specified name server list.Returns the dns server address stream used for DNS queries (not resolve).longReturns the timeout of each DNS query performed by this resolver (in milliseconds).private static ChannelFutureregisterOrBind(Bootstrap bootstrap, SocketAddress localAddress) final Future<InetAddress> Resolves the specified name into an address.final Future<InetAddress> Resolves the specified name into an address.resolveAll(DnsQuestion question) Resolves theDnsRecords that are matched by the specifiedDnsQuestion.resolveAll(DnsQuestion question, DnsRecord[] additionals, Promise<List<DnsRecord>> promise) resolveAll(DnsQuestion question, Iterable<DnsRecord> additionals) Resolves theDnsRecords that are matched by the specifiedDnsQuestion.resolveAll(DnsQuestion question, Iterable<DnsRecord> additionals, Promise<List<DnsRecord>> promise) Resolves theDnsRecords that are matched by the specifiedDnsQuestion.final Future<List<InetAddress>> resolveAll(String inetHost, Iterable<DnsRecord> additionals) Resolves the specified host name and port into a list of address.final Future<List<InetAddress>> resolveAll(String inetHost, Iterable<DnsRecord> additionals, Promise<List<InetAddress>> promise) Resolves the specified host name and port into a list of address.private voidresolveAllNow(ChannelFuture f, String hostname, DnsQuestion question, DnsRecord[] additionals, Promise<List<DnsRecord>> promise) Returns the resolution cache.Returns theResolvedAddressTypesresolved bySimpleNameResolver.resolve(String).(package private) InternetProtocolFamily[]private List<InetAddress> resolveHostsFileEntries(String hostname) private InetAddressresolveHostsFileEntry(String hostname) private voidresolveNow(Channel channel, String hostname, DnsRecord[] additionals, Promise<?> originalPromise, Promise<List<InetAddress>> promise, DnsCache resolveCache, boolean completeEarlyIfPossible) (package private) final DnsRecordType[](package private) final String[](package private) final boolean(package private) final booleanprivate static DnsRecord[]private static UnknownHostExceptiontoException(ChannelFuture f, String hostname, DnsQuestion question, DnsRecord[] additionals) private static voidtryFailure(Promise<?> promise, Throwable cause) (package private) static <T> booleantrySuccess(Promise<T> promise, T result) private static voidvalidateAdditional(DnsRecord record, boolean validateType) Methods inherited from class io.netty.resolver.InetNameResolver
asAddressResolverMethods inherited from class io.netty.resolver.SimpleNameResolver
resolve, resolve, resolveAll, resolveAll
-
Field Details
-
DNS_PIPELINE_ATTRIBUTE
An attribute used to mark all channels created by theDnsNameResolver. -
logger
-
LOCALHOST
- See Also:
-
WINDOWS_HOST_NAME
-
LOCALHOST_ADDRESS
-
EMPTY_ADDITIONALS
-
IPV4_ONLY_RESOLVED_RECORD_TYPES
-
IPV4_ONLY_RESOLVED_PROTOCOL_FAMILIES
-
IPV4_PREFERRED_RESOLVED_RECORD_TYPES
-
IPV4_PREFERRED_RESOLVED_PROTOCOL_FAMILIES
-
IPV6_ONLY_RESOLVED_RECORD_TYPES
-
IPV6_ONLY_RESOLVED_PROTOCOL_FAMILIES
-
IPV6_PREFERRED_RESOLVED_RECORD_TYPES
-
IPV6_PREFERRED_RESOLVED_PROTOCOL_FAMILIES
-
NOOP_HANDLER
-
DEFAULT_RESOLVE_ADDRESS_TYPES
-
DEFAULT_SEARCH_DOMAINS
-
DEFAULT_OPTIONS
-
DATAGRAM_DECODER
-
DATAGRAM_ENCODER
-
nameServerComparator
-
queryContextManager
Manages theDnsQueryContexts in progress and their query IDs. -
resolveCache
Cache fordoResolve(String, Promise)anddoResolveAll(String, Promise). -
authoritativeDnsServerCache
-
cnameCache
-
queryDnsServerAddressStream
-
queryTimeoutMillis
private final long queryTimeoutMillis -
maxQueriesPerResolve
private final int maxQueriesPerResolve -
resolvedAddressTypes
-
resolvedInternetProtocolFamilies
-
recursionDesired
private final boolean recursionDesired -
maxPayloadSize
private final int maxPayloadSize -
optResourceEnabled
private final boolean optResourceEnabled -
hostsFileEntriesResolver
-
dnsServerAddressStreamProvider
-
searchDomains
-
ndots
private final int ndots -
supportsAAAARecords
private final boolean supportsAAAARecords -
supportsARecords
private final boolean supportsARecords -
preferredAddressType
-
resolveRecordTypes
-
decodeIdn
private final boolean decodeIdn -
dnsQueryLifecycleObserverFactory
-
completeOncePreferredResolved
private final boolean completeOncePreferredResolved -
resolveChannelProvider
-
socketBootstrap
-
retryWithTcpOnTimeout
private final boolean retryWithTcpOnTimeout -
maxNumConsolidation
private final int maxNumConsolidation -
inflightLookups
-
-
Constructor Details
-
DnsNameResolver
@Deprecated public DnsNameResolver(EventLoop eventLoop, ChannelFactory<? extends DatagramChannel> channelFactory, DnsCache resolveCache, DnsCache authoritativeDnsServerCache, DnsQueryLifecycleObserverFactory dnsQueryLifecycleObserverFactory, long queryTimeoutMillis, ResolvedAddressTypes resolvedAddressTypes, boolean recursionDesired, int maxQueriesPerResolve, boolean traceEnabled, int maxPayloadSize, boolean optResourceEnabled, HostsFileEntriesResolver hostsFileEntriesResolver, DnsServerAddressStreamProvider dnsServerAddressStreamProvider, String[] searchDomains, int ndots, boolean decodeIdn) Deprecated.Creates a new DNS-based name resolver that communicates with the specified list of DNS servers.- Parameters:
eventLoop- theEventLoopwhich will perform the communication with the DNS serverschannelFactory- theChannelFactorythat will create aDatagramChannelresolveCache- the DNS resolved entries cacheauthoritativeDnsServerCache- the cache used to find the authoritative DNS server for a domaindnsQueryLifecycleObserverFactory- used to generate new instances ofDnsQueryLifecycleObserverwhich can be used to track metrics for DNS servers.queryTimeoutMillis- timeout of each DNS query in millis.0disables the timeout. If not set or a negative number is set, the default timeout is used.resolvedAddressTypes- the preferred address typesrecursionDesired- if recursion desired flag must be setmaxQueriesPerResolve- the maximum allowed number of DNS queries for a given name resolutiontraceEnabled- if trace is enabledmaxPayloadSize- the capacity of the datagram packet bufferoptResourceEnabled- if automatic inclusion of a optional records is enabledhostsFileEntriesResolver- theHostsFileEntriesResolverused to check for local aliasesdnsServerAddressStreamProvider- TheDnsServerAddressStreamProviderused to determine the name servers for each hostname lookup.searchDomains- the list of search domain (can be null, if so, will try to default to the underlying platform ones)ndots- the ndots valuedecodeIdn-trueif domain / host names should be decoded to unicode when received. See rfc3492.
-
DnsNameResolver
@Deprecated public DnsNameResolver(EventLoop eventLoop, ChannelFactory<? extends DatagramChannel> channelFactory, DnsCache resolveCache, AuthoritativeDnsServerCache authoritativeDnsServerCache, DnsQueryLifecycleObserverFactory dnsQueryLifecycleObserverFactory, long queryTimeoutMillis, ResolvedAddressTypes resolvedAddressTypes, boolean recursionDesired, int maxQueriesPerResolve, boolean traceEnabled, int maxPayloadSize, boolean optResourceEnabled, HostsFileEntriesResolver hostsFileEntriesResolver, DnsServerAddressStreamProvider dnsServerAddressStreamProvider, String[] searchDomains, int ndots, boolean decodeIdn) Deprecated.Creates a new DNS-based name resolver that communicates with the specified list of DNS servers.- Parameters:
eventLoop- theEventLoopwhich will perform the communication with the DNS serverschannelFactory- theChannelFactorythat will create aDatagramChannelresolveCache- the DNS resolved entries cacheauthoritativeDnsServerCache- the cache used to find the authoritative DNS server for a domaindnsQueryLifecycleObserverFactory- used to generate new instances ofDnsQueryLifecycleObserverwhich can be used to track metrics for DNS servers.queryTimeoutMillis- timeout of each DNS query in millis.0disables the timeout. If not set or a negative number is set, the default timeout is used.resolvedAddressTypes- the preferred address typesrecursionDesired- if recursion desired flag must be setmaxQueriesPerResolve- the maximum allowed number of DNS queries for a given name resolutiontraceEnabled- if trace is enabledmaxPayloadSize- the capacity of the datagram packet bufferoptResourceEnabled- if automatic inclusion of a optional records is enabledhostsFileEntriesResolver- theHostsFileEntriesResolverused to check for local aliasesdnsServerAddressStreamProvider- TheDnsServerAddressStreamProviderused to determine the name servers for each hostname lookup.searchDomains- the list of search domain (can be null, if so, will try to default to the underlying platform ones)ndots- the ndots valuedecodeIdn-trueif domain / host names should be decoded to unicode when received. See rfc3492.
-
DnsNameResolver
DnsNameResolver(EventLoop eventLoop, ChannelFactory<? extends DatagramChannel> channelFactory, ChannelFactory<? extends SocketChannel> socketChannelFactory, boolean retryWithTcpOnTimeout, DnsCache resolveCache, DnsCnameCache cnameCache, AuthoritativeDnsServerCache authoritativeDnsServerCache, SocketAddress localAddress, DnsQueryLifecycleObserverFactory dnsQueryLifecycleObserverFactory, long queryTimeoutMillis, ResolvedAddressTypes resolvedAddressTypes, boolean recursionDesired, int maxQueriesPerResolve, boolean traceEnabled, int maxPayloadSize, boolean optResourceEnabled, HostsFileEntriesResolver hostsFileEntriesResolver, DnsServerAddressStreamProvider dnsServerAddressStreamProvider, DnsServerAddressStream queryDnsServerAddressStream, String[] searchDomains, int ndots, boolean decodeIdn, boolean completeOncePreferredResolved, int maxNumConsolidation, DnsNameResolverChannelStrategy datagramChannelStrategy)
-
-
Method Details
-
anyInterfaceSupportsIpV6
private static boolean anyInterfaceSupportsIpV6() -
getSearchDomainsHack
- Throws:
Exception
-
newProvider
private static DnsNameResolver.DnsResolveChannelProvider newProvider(DnsNameResolverChannelStrategy channelStrategy, Bootstrap bootstrap, SocketAddress localAddress) -
preferredAddressType
-
newRedirectServerAddress
-
dnsQueryLifecycleObserverFactory
-
newRedirectDnsServerStream
protected DnsServerAddressStream newRedirectDnsServerStream(String hostname, List<InetSocketAddress> nameservers) Creates a newDnsServerAddressStreamto following a redirected DNS query. By overriding this it provides the opportunity to sort the name servers before following a redirected DNS query.- Parameters:
hostname- the hostname.nameservers- The addresses of the DNS servers which are used in the event of a redirect. This may contain resolved and unresolved addresses so the usedDnsServerAddressStreammust allow unresolved addresses if you want to include these as well.- Returns:
- A
DnsServerAddressStreamwhich will be used to follow the DNS redirect ornullif none should be followed.
-
resolveCache
Returns the resolution cache. -
cnameCache
Returns theDnsCnameCache. -
authoritativeDnsServerCache
Returns the cache used for authoritative DNS servers for a domain. -
queryTimeoutMillis
public long queryTimeoutMillis()Returns the timeout of each DNS query performed by this resolver (in milliseconds). The default value is 5 seconds. -
queryDnsServerAddressStream
Returns the dns server address stream used for DNS queries (not resolve). -
resolvedAddressTypes
Returns theResolvedAddressTypesresolved bySimpleNameResolver.resolve(String). The default value depends on the value of the system property"java.net.preferIPv6Addresses". -
resolvedInternetProtocolFamiliesUnsafe
InternetProtocolFamily[] resolvedInternetProtocolFamiliesUnsafe() -
searchDomains
-
ndots
final int ndots() -
supportsAAAARecords
final boolean supportsAAAARecords() -
supportsARecords
final boolean supportsARecords() -
preferredAddressType
-
resolveRecordTypes
-
isDecodeIdn
final boolean isDecodeIdn() -
isRecursionDesired
public boolean isRecursionDesired()Returnstrueif and only if this resolver sends a DNS query with the RD (recursion desired) flag set. The default value istrue. -
maxQueriesPerResolve
public int maxQueriesPerResolve()Returns the maximum allowed number of DNS queries to send when resolving a host name. The default value is8. -
maxPayloadSize
public int maxPayloadSize()Returns the capacity of the datagram packet buffer (in bytes). The default value is4096bytes. -
isOptResourceEnabled
public boolean isOptResourceEnabled()Returns the automatic inclusion of a optional records that tries to give the remote DNS server a hint about how much data the resolver can read per response is enabled. -
hostsFileEntriesResolver
Returns the component that tries to resolve hostnames against the hosts file prior to asking to remotes DNS servers. -
close
public void close()Closes the internal datagram channel used for sending and receiving DNS messages, and clears all DNS resource records from the cache. Attempting to send a DNS query or to resolve a domain name will fail once this method has been called.- Specified by:
closein interfaceAutoCloseable- Specified by:
closein interfaceCloseable- Specified by:
closein interfaceNameResolver<InetAddress>- Overrides:
closein classSimpleNameResolver<InetAddress>
-
executor
Description copied from class:SimpleNameResolverReturns theEventExecutorwhich is used to notify the listeners of theFuturereturned bySimpleNameResolver.resolve(String).- Overrides:
executorin classSimpleNameResolver<InetAddress>
-
resolveHostsFileEntry
-
resolveHostsFileEntries
-
isLocalWindowsHost
Checks whether the given hostname is the localhost/host (computer) name on Windows OS. Windows OS removed the localhost/host (computer) name information from the hosts file in the later versions and such hostname cannot be resolved from hosts file. See https://github.com/netty/netty/issues/5386 See https://github.com/netty/netty/issues/11142 -
resolve
Resolves the specified name into an address.- Parameters:
inetHost- the name to resolveadditionals- additional records (OPT)- Returns:
- the address as the result of the resolution
-
resolve
public final Future<InetAddress> resolve(String inetHost, Iterable<DnsRecord> additionals, Promise<InetAddress> promise) Resolves the specified name into an address.- Parameters:
inetHost- the name to resolveadditionals- additional records (OPT)promise- thePromisewhich will be fulfilled when the name resolution is finished- Returns:
- the address as the result of the resolution
-
resolveAll
Resolves the specified host name and port into a list of address.- Parameters:
inetHost- the name to resolveadditionals- additional records (OPT)- Returns:
- the list of the address as the result of the resolution
-
resolveAll
public final Future<List<InetAddress>> resolveAll(String inetHost, Iterable<DnsRecord> additionals, Promise<List<InetAddress>> promise) Resolves the specified host name and port into a list of address.- Parameters:
inetHost- the name to resolveadditionals- additional records (OPT)promise- thePromisewhich will be fulfilled when the name resolution is finished- Returns:
- the list of the address as the result of the resolution
-
doResolve
Description copied from class:SimpleNameResolverInvoked bySimpleNameResolver.resolve(String)to perform the actual name resolution.- Specified by:
doResolvein classSimpleNameResolver<InetAddress>- Throws:
Exception
-
resolveAll
Resolves theDnsRecords that are matched by the specifiedDnsQuestion. Unlikequery(DnsQuestion), this method handles redirection, CNAMEs and multiple name servers. If the specifiedDnsQuestionisAorAAAA, this method looks up the configuredHostsFileEntriesbefore sending a query to the name servers. If a match is found in theHostsFileEntries, a syntheticAorAAAArecord will be returned.- Parameters:
question- the question- Returns:
- the list of the
DnsRecords as the result of the resolution
-
resolveAll
public final Future<List<DnsRecord>> resolveAll(DnsQuestion question, Iterable<DnsRecord> additionals) Resolves theDnsRecords that are matched by the specifiedDnsQuestion. Unlikequery(DnsQuestion), this method handles redirection, CNAMEs and multiple name servers. If the specifiedDnsQuestionisAorAAAA, this method looks up the configuredHostsFileEntriesbefore sending a query to the name servers. If a match is found in theHostsFileEntries, a syntheticAorAAAArecord will be returned.- Parameters:
question- the questionadditionals- additional records (OPT)- Returns:
- the list of the
DnsRecords as the result of the resolution
-
resolveAll
public final Future<List<DnsRecord>> resolveAll(DnsQuestion question, Iterable<DnsRecord> additionals, Promise<List<DnsRecord>> promise) Resolves theDnsRecords that are matched by the specifiedDnsQuestion. Unlikequery(DnsQuestion), this method handles redirection, CNAMEs and multiple name servers. If the specifiedDnsQuestionisAorAAAA, this method looks up the configuredHostsFileEntriesbefore sending a query to the name servers. If a match is found in theHostsFileEntries, a syntheticAorAAAArecord will be returned. -
resolveAll
-
resolveAllNow
private void resolveAllNow(ChannelFuture f, String hostname, DnsQuestion question, DnsRecord[] additionals, Promise<List<DnsRecord>> promise) -
toException
private static UnknownHostException toException(ChannelFuture f, String hostname, DnsQuestion question, DnsRecord[] additionals) -
toArray
-
validateAdditional
-
loopbackAddress
-
doResolve
protected void doResolve(String inetHost, DnsRecord[] additionals, Promise<InetAddress> promise, DnsCache resolveCache) throws Exception Hook designed for extensibility so one can pass a different cache on each resolution attempt instead of using the global one.- Throws:
Exception
-
doResolveNow
private void doResolveNow(ChannelFuture f, String hostname, DnsRecord[] additionals, Promise<InetAddress> promise, DnsCache resolveCache) -
doResolveCached
private boolean doResolveCached(String hostname, DnsRecord[] additionals, Promise<InetAddress> promise, DnsCache resolveCache) -
trySuccess
-
tryFailure
-
doResolveUncached
-
doResolveAll
Description copied from class:SimpleNameResolverInvoked bySimpleNameResolver.resolveAll(String)to perform the actual name resolution.- Specified by:
doResolveAllin classSimpleNameResolver<InetAddress>- Throws:
Exception
-
doResolveAll
protected void doResolveAll(String inetHost, DnsRecord[] additionals, Promise<List<InetAddress>> promise, DnsCache resolveCache) throws Exception Hook designed for extensibility so one can pass a different cache on each resolution attempt instead of using the global one.- Throws:
Exception
-
doResolveAllNow
private void doResolveAllNow(ChannelFuture f, String hostname, DnsRecord[] additionals, Promise<List<InetAddress>> promise, DnsCache resolveCache) -
hasEntries
-
doResolveAllCached
static boolean doResolveAllCached(String hostname, DnsRecord[] additionals, Promise<List<InetAddress>> promise, DnsCache resolveCache, String[] searchDomains, int ndots, InternetProtocolFamily[] resolvedInternetProtocolFamilies) -
doResolveAllUncached
-
doResolveAllUncached0
-
resolveNow
-
hostname
-
query
Sends a DNS query with the specified question. -
query
public Future<AddressedEnvelope<DnsResponse,InetSocketAddress>> query(DnsQuestion question, Iterable<DnsRecord> additionals) Sends a DNS query with the specified question with additional records. -
query
public Future<AddressedEnvelope<DnsResponse,InetSocketAddress>> query(DnsQuestion question, Promise<AddressedEnvelope<? extends DnsResponse, InetSocketAddress>> promise) Sends a DNS query with the specified question. -
nextNameServerAddress
-
query
public Future<AddressedEnvelope<DnsResponse,InetSocketAddress>> query(InetSocketAddress nameServerAddr, DnsQuestion question) Sends a DNS query with the specified question using the specified name server list. -
query
public Future<AddressedEnvelope<DnsResponse,InetSocketAddress>> query(InetSocketAddress nameServerAddr, DnsQuestion question, Iterable<DnsRecord> additionals) Sends a DNS query with the specified question with additional records using the specified name server list. -
query
public Future<AddressedEnvelope<DnsResponse,InetSocketAddress>> query(InetSocketAddress nameServerAddr, DnsQuestion question, Promise<AddressedEnvelope<? extends DnsResponse, InetSocketAddress>> promise) Sends a DNS query with the specified question using the specified name server list. -
query
public Future<AddressedEnvelope<DnsResponse,InetSocketAddress>> query(InetSocketAddress nameServerAddr, DnsQuestion question, Iterable<DnsRecord> additionals, Promise<AddressedEnvelope<? extends DnsResponse, InetSocketAddress>> promise) Sends a DNS query with the specified question with additional records using the specified name server list. -
isTransportOrTimeoutError
Returnstrueif theThrowablewas caused by an timeout or transport error. These methods can be used on theFuture.cause()that is returned by the various methods exposed by thisDnsNameResolver. -
isTimeoutError
Returnstrueif theThrowablewas caused by an timeout. These methods can be used on theFuture.cause()that is returned by the various methods exposed by thisDnsNameResolver. -
doQuery
final Future<AddressedEnvelope<DnsResponse,InetSocketAddress>> doQuery(Channel channel, InetSocketAddress nameServerAddr, DnsQuestion question, DnsQueryLifecycleObserver queryLifecycleObserver, DnsRecord[] additionals, boolean flush, Promise<AddressedEnvelope<? extends DnsResponse, InetSocketAddress>> promise) -
cast
-
newNameServerAddressStream
-
registerOrBind
-
DnsNameResolverBuilder.