1inet_res(3) Erlang Module Definition inet_res(3)
2
3
4
6 inet_res - A rudimentary DNS client.
7
9 This module performs DNS name resolving to recursive name servers.
10
11 See also ERTS User's Guide: Inet Configuration for more information
12 about how to configure an Erlang runtime system for IP communication,
13 and how to enable this DNS client by defining 'dns' as a lookup method.
14 The DNS client then acts as a backend for the resolving functions in
15 inet.
16
17 This DNS client can resolve DNS records even if it is not used for nor‐
18 mal name resolving in the node.
19
20 This is not a full-fledged resolver, only a DNS client that relies on
21 asking trusted recursive name servers.
22
24 UDP queries are used unless resolver option usevc is true, which forces
25 TCP queries. If the query is too large for UDP, TCP is used instead.
26 For regular DNS queries, 512 bytes is the size limit.
27
28 When EDNS is enabled (resolver option edns is set to the EDNS version
29 (that is, 0 instead of false), resolver option udp_payload_size sets
30 the limit. If a name server replies with the TC bit set (truncation),
31 indicating that the answer is incomplete, the query is retried to that
32 name server using TCP. Resolver option udp_payload_size also sets the
33 advertised size for the maximum allowed reply size, if EDNS is enabled,
34 otherwise the name server uses the limit 512 bytes. If the reply is
35 larger, it gets truncated, forcing a TCP requery.
36
37 For UDP queries, resolver options timeout and retry control retransmis‐
38 sion. Each name server in the nameservers list is tried with a time-out
39 of timeout/retry. Then all name servers are tried again, doubling the
40 time-out, for a total of retry times.
41
42 But before all name servers are tried again, there is a (user config‐
43 urable) timeout, servfail_retry_timeout. The point of this is to pre‐
44 vent the new query to be handled by a server's servfail cache (a client
45 that is to eager will actually only get what is in the servfail cache).
46 If there is too little time left of the resolver call's timeout to do a
47 retry, the resolver call may return before the call's timeout has ex‐
48 pired.
49
50 For queries not using the search list, if the query to all nameservers
51 results in {error,nxdomain} or an empty answer, the same query is tried
52 for alt_nameservers.
53
55 The following data types concern the resolver:
56
58 res_option() =
59 {alt_nameservers, [nameserver()]} |
60 {edns, 0 | false} |
61 {inet6, boolean()} |
62 {nameservers, [nameserver()]} |
63 {recurse, boolean()} |
64 {retry, integer()} |
65 {timeout, integer()} |
66 {udp_payload_size, integer()} |
67 {usevc, boolean()} |
68 {nxdomain_reply, boolean()}
69
70 nameserver() = {inet:ip_address(), Port :: 1..65535}
71
72 res_error() =
73 formerr | qfmterror | servfail | nxdomain | notimp | refused |
74 badvers | timeout
75
77 The following data types concern the DNS client:
78
80 dns_name() = string()
81
82 A string with no adjacent dots.
83
84 rr_type() =
85 a | aaaa | caa | cname | gid | hinfo | ns | mb | md | mg |
86 mf | minfo | mx | naptr | null | ptr | soa | spf | srv | txt |
87 uid | uinfo | unspec | uri | wks
88
89 dns_class() = in | chaos | hs | any
90
91 dns_msg() = term()
92
93 This is the start of a hiearchy of opaque data structures that
94 can be examined with access functions in inet_dns, which return
95 lists of {Field,Value} tuples. The arity 2 functions only return
96 the value for a specified field.
97
98 dns_msg() = DnsMsg
99 inet_dns:msg(DnsMsg) ->
100 [ {header, dns_header()}
101 | {qdlist, dns_query()}
102 | {anlist, dns_rr()}
103 | {nslist, dns_rr()}
104 | {arlist, dns_rr()} ]
105 inet_dns:msg(DnsMsg, header) -> dns_header() % for example
106 inet_dns:msg(DnsMsg, Field) -> Value
107
108 dns_header() = DnsHeader
109 inet_dns:header(DnsHeader) ->
110 [ {id, integer()}
111 | {qr, boolean()}
112 | {opcode, query | iquery | status | integer()}
113 | {aa, boolean()}
114 | {tc, boolean()}
115 | {rd, boolean()}
116 | {ra, boolean()}
117 | {pr, boolean()}
118 | {rcode, integer(0..16)} ]
119 inet_dns:header(DnsHeader, Field) -> Value
120
121 query_type() = axfr | mailb | maila | any | rr_type()
122
123 dns_query() = DnsQuery
124 inet_dns:dns_query(DnsQuery) ->
125 [ {domain, dns_name()}
126 | {type, query_type()}
127 | {class, dns_class()} ]
128 inet_dns:dns_query(DnsQuery, Field) -> Value
129
130 dns_rr() = DnsRr
131 inet_dns:rr(DnsRr) -> DnsRrFields | DnsRrOptFields
132 DnsRrFields = [ {domain, dns_name()}
133 | {type, rr_type()}
134 | {class, dns_class()}
135 | {ttl, integer()}
136 | {data, dns_data()} ]
137 DnsRrOptFields = [ {domain, dns_name()}
138 | {type, opt}
139 | {udp_payload_size, integer()}
140 | {ext_rcode, integer()}
141 | {version, integer()}
142 | {z, integer()}
143 | {data, dns_data()} ]
144 inet_dns:rr(DnsRr, Field) -> Value
145
146 There is an information function for the types above:
147
148 inet_dns:record_type(dns_msg()) -> msg;
149 inet_dns:record_type(dns_header()) -> header;
150 inet_dns:record_type(dns_query()) -> dns_query;
151 inet_dns:record_type(dns_rr()) -> rr;
152 inet_dns:record_type(_) -> undefined.
153
154 So, inet_dns:(inet_dns:record_type(X))(X) converts any of these
155 data structures into a {Field,Value} list.
156
157 dns_data() =
158 dns_name() |
159 inet:ip4_address() |
160 inet:ip6_address() |
161 {MName :: dns_name(),
162 RName :: dns_name(),
163 Serial :: integer(),
164 Refresh :: integer(),
165 Retry :: integer(),
166 Expiry :: integer(),
167 Minimum :: integer()} |
168 {inet:ip4_address(), Proto :: integer(), BitMap :: binary()} |
169 {CpuString :: string(), OsString :: string()} |
170 {RM :: dns_name(), EM :: dns_name()} |
171 {Prio :: integer(), dns_name()} |
172 {Prio :: integer(),
173 Weight :: integer(),
174 Port :: integer(),
175 dns_name()} |
176 {Order :: integer(),
177 Preference :: integer(),
178 Flags :: string(),
179 Services :: string(),
180 Regexp :: string(),
181 dns_name()} |
182 [string()] |
183 binary()
184
185 Regexp is a string with characters encoded in the UTF-8 coding
186 standard.
187
189 getbyname(Name, Type) -> {ok, Hostent} | {error, Reason}
190
191 getbyname(Name, Type, Timeout) -> {ok, Hostent} | {error, Reason}
192
193 Types:
194
195 Name = dns_name()
196 Type = rr_type()
197 Timeout = timeout()
198 Hostent = inet:hostent()
199 Reason = inet:posix() | res_error()
200
201 Resolves a DNS record of the specified type for the specified
202 host, of class in. Returns, on success, a hostent() record with
203 dns_data() elements in the address list field.
204
205 This function uses resolver option search that is a list of do‐
206 main names. If the name to resolve contains no dots, it is
207 prepended to each domain name in the search list, and they are
208 tried in order. If the name contains dots, it is first tried as
209 an absolute name and if that fails, the search list is used. If
210 the name has a trailing dot, it is supposed to be an absolute
211 name and the search list is not used.
212
213 gethostbyaddr(Address) -> {ok, Hostent} | {error, Reason}
214
215 gethostbyaddr(Address, Timeout) -> {ok, Hostent} | {error, Reason}
216
217 Types:
218
219 Address = inet:ip_address()
220 Timeout = timeout()
221 Hostent = inet:hostent()
222 Reason = inet:posix() | res_error()
223
224 Backend functions used by inet:gethostbyaddr/1.
225
226 gethostbyname(Name) -> {ok, Hostent} | {error, Reason}
227
228 gethostbyname(Name, Family) -> {ok, Hostent} | {error, Reason}
229
230 gethostbyname(Name, Family, Timeout) ->
231 {ok, Hostent} | {error, Reason}
232
233 Types:
234
235 Name = dns_name()
236 Hostent = inet:hostent()
237 Timeout = timeout()
238 Family = inet:address_family()
239 Reason = inet:posix() | res_error()
240
241 Backend functions used by inet:gethostbyname/1,2.
242
243 This function uses resolver option search just like getby‐
244 name/2,3.
245
246 If resolver option inet6 is true, an IPv6 address is looked up.
247
248 lookup(Name, Class, Type) -> [dns_data()]
249
250 lookup(Name, Class, Type, Opts) -> [dns_data()]
251
252 lookup(Name, Class, Type, Opts, Timeout) -> [dns_data()]
253
254 Types:
255
256 Name = dns_name() | inet:ip_address()
257 Class = dns_class()
258 Type = rr_type()
259 Opts = [res_option() | verbose]
260 Timeout = timeout()
261
262 Resolves the DNS data for the record of the specified type and
263 class for the specified name. On success, filters out the answer
264 records with the correct Class and Type, and returns a list of
265 their data fields. So, a lookup for type any gives an empty an‐
266 swer, as the answer records have specific types that are not
267 any. An empty answer or a failed lookup returns an empty list.
268
269 Calls resolve/* with the same arguments and filters the result,
270 so Opts is described for those functions.
271
272 resolve(Name, Class, Type) -> {ok, dns_msg()} | Error
273
274 resolve(Name, Class, Type, Opts) -> {ok, dns_msg()} | Error
275
276 resolve(Name, Class, Type, Opts, Timeout) ->
277 {ok, dns_msg()} | Error
278
279 Types:
280
281 Name = dns_name() | inet:ip_address()
282 Class = dns_class()
283 Type = rr_type()
284 Opts = [Opt]
285 Opt = res_option() | verbose | atom()
286 Timeout = timeout()
287 Error = {error, Reason} | {error, {Reason, dns_msg()}}
288 Reason = inet:posix() | res_error()
289
290 Resolves a DNS record of the specified type and class for the
291 specified name. The returned dns_msg() can be examined using ac‐
292 cess functions in inet_db, as described in section in DNS Types.
293
294 If Name is an ip_address(), the domain name to query for is gen‐
295 erated as the standard reverse ".IN-ADDR.ARPA." name for an IPv4
296 address, or the ".IP6.ARPA." name for an IPv6 address. In this
297 case, you most probably want to use Class = in and Type = ptr,
298 but it is not done automatically.
299
300 Opts overrides the corresponding resolver options. If option
301 nameservers is specified, it is assumed that it is the complete
302 list of name serves, so resolver option alt_nameserves is ig‐
303 nored. However, if option alt_nameserves is also specified to
304 this function, it is used.
305
306 Option verbose (or rather {verbose,true}) causes diagnostics
307 printout through io:format/2 of queries, replies retransmis‐
308 sions, and so on, similar to from utilities, such as dig and
309 nslookup.
310
311 Option nxdomain_reply (or rather {nxdomain_reply,true}) causes
312 nxdomain errors from DNS servers to be returned as {error, {nx‐
313 domain, dns_msg()}}. dns_msg() contains the additional sections
314 that where included by the answering server. This is mainly use‐
315 ful to inspect the SOA record to get the TTL for negative
316 caching.
317
318 If Opt is any atom, it is interpreted as {Opt,true} unless the
319 atom string starts with "no", making the interpretation
320 {Opt,false}. For example, usevc is an alias for {usevc,true} and
321 nousevc is an alias for {usevc,false}.
322
323 Option inet6 has no effect on this function. You probably want
324 to use Type = a | aaaa instead.
325
327 This access functions example shows how lookup/3 can be implemented us‐
328 ing resolve/3 from outside the module:
329
330 example_lookup(Name, Class, Type) ->
331 case inet_res:resolve(Name, Class, Type) of
332 {ok,Msg} ->
333 [inet_dns:rr(RR, data)
334 || RR <- inet_dns:msg(Msg, anlist),
335 inet_dns:rr(RR, type) =:= Type,
336 inet_dns:rr(RR, class) =:= Class];
337 {error,_} ->
338 []
339 end.
340
342 These are deprecated because the annoying double meaning of the name
343 servers/time-out argument, and because they have no decent place for a
344 resolver options list.
345
347 nslookup(Name, Class, Type) -> {ok, dns_msg()} | {error, Reason}
348
349 nslookup(Name, Class, Type, Timeout) ->
350 {ok, dns_msg()} | {error, Reason}
351
352 nslookup(Name, Class, Type, Nameservers) ->
353 {ok, dns_msg()} | {error, Reason}
354
355 Types:
356
357 Name = dns_name() | inet:ip_address()
358 Class = dns_class()
359 Type = rr_type()
360 Timeout = timeout()
361 Nameservers = [nameserver()]
362 Reason = inet:posix() | res_error()
363
364 Resolves a DNS record of the specified type and class for the
365 specified name.
366
367 nnslookup(Name, Class, Type, Nameservers) ->
368 {ok, dns_msg()} | {error, Reason}
369
370 nnslookup(Name, Class, Type, Nameservers, Timeout) ->
371 {ok, dns_msg()} | {error, Reason}
372
373 Types:
374
375 Name = dns_name() | inet:ip_address()
376 Class = dns_class()
377 Type = rr_type()
378 Timeout = timeout()
379 Nameservers = [nameserver()]
380 Reason = inet:posix()
381
382 Resolves a DNS record of the specified type and class for the
383 specified name.
384
385
386
387Ericsson AB kernel 8.3.2 inet_res(3)