gethostent(3N)
gethostent --
get network host entry
Synopsis
cc [options] file -lsocket -lnsl
#include <netdb.h>
extern int h_errno;
struct hostent *gethostent(void);
struct hostent *gethostbyname(const char *name);
struct hostent *gethostbyname2(const char *name, int af);
struct hostent *gethostbyaddr(const char *addr, int len, int type);
void sethostent(int stayopen);
void endhostent(void)
void herror(const char *string);
char * hstrerror(int error);
Description
gethostent reads a line from /etc/hosts,
opening the file if necessary.
It returns a pointer to a structure of type hostent
which describes an internet host.
sethostent allows gethostent to read
subsequent lines from /etc/hosts.
If the stayopen argument is non-zero, the hosts'
database will not be closed after each call to gethostent.
sethostent opens
a connected TCP socket for queries, and retains the
connection after each call to gethostent.
If stayopen is zero,
queries are performed using UDP datagrams and
the file is re-opened (and rewound) on each invocation
of gethostent.
endhostent closes the TCP connection.
gethostbyname, gethostbyname2 and gethostbyaddr
also return a pointer to a structure of type hostent
which describes an internet host.
These routines search for this description, by hostname, hostname and
address family or by host address, respectively, in any or all of the following
databases:
the Domain Name System (DNS),
the Network Information Service (NIS),
and the file /etc/hosts.
NOTE:
For gethostbyname2, use the af argument to specify the
address family. Valid address families are AF_INET (IP
version 4) and AF_INET6 (IP version 6). If you do
not specify a valid address family, this function returns NULL,
and sets h_errno to NETDB_INTERNAL.
gethostbyname assumes AF_INET by default.
The order and number of databases searched depends on the value
assigned to the keyword hostresorder in the file
/etc/resolv.conf (see
resolv.conf(4tcp)).
NOTE:
These routines do not read /etc/resolv.conf directly.
They invoke the resolver routine res_init (see
resolver(3N)).
The hostent structure is defined as follows:
struct hostent {
char *h_name; /* official name of host */
char **h_aliases; /* alias list */
int h_addrtype; /* host address type */
int h_length; /* length of address */
char **h_addr_list; /* list of addresses from name server */
};
#define h_addr h_addr_list[0] /* address, for backward compatibility */
The members of this structure are:
h_name
-
Official name of the host.
h_aliases
-
A null-terminated array of alternate names for the host.
h_addrtype
-
The type of address being returned; currently either AF_INET or
AF_INET6.
h_length
-
The length, in bytes, of the address.
h_addr_list
-
A null-terminated array of network addresses for the host.
Host addresses are returned in network byte order in
struct in_addr for AF_INET and
struct in6_addr for AF_INET6.
h_addr
-
The first address in
h_addr_list
;
this is for backward compatibility.
When using the name server,
gethostbyname and gethostbyname2
search for the named host in the current domain and then its parents,
unless the name ends in a dot.
If the name contains no dot, and if the environment
variable HOSTALIASES contains the name of
an alias file, the alias file is first searched
for an alias matching the input name.
See
hostname(1bsd)
for the domain search procedure and the alias file format.
Files
/etc/hosts
/etc/resolv.conf
Diagnostics
Error return status from gethostbyname,
gethostbyname2
and gethostbyaddr
is indicated by return of a null pointer.
The external integer h_errno
may then be checked to see whether this is a temporary failure
or an invalid or unknown host.
The routine herror
can be used to print an error message describing the failure.
If the argument string
is non-NULL, it is printed, followed by a colon and a space.
The error message is printed with a trailing newline.
h_errno can have the following values:
- NETDB_INTERNAL
-
This indicates an internal error in the library, unrelated
to the network or name service. errno is valid
in this case.
- HOST_NOT_FOUND
-
No such host is known.
- TRY_AGAIN
-
This is usually a temporary error
and means that the local server did not receive
a response from an authoritative server.
A retry at some later time may succeed.
- NO_RECOVERY
-
Some unexpected server failure was encountered.
This is a non-recoverable error.
- NO_DATA
-
The requested name is valid but does not have an IP address;
this is not a temporary error.
This means that the name is known to the name server but there is no address
associated with this name.
Another type of request to the name server using this domain name
will result in an answer;
for example, a mail-forwarder may be registered for this domain.
The
hstrerror
routine returns a pointer to the error message text associated with the
value of its argument.
References
getaddrinfo(3N),
getnameinfo(3N),
hosts(4tcp),
hostname(1bsd),
named(1Mtcp),
resolv.conf(4tcp),
resolver(3N)
Notices
All information is contained in a static area
so it must be copied if it is to be saved.
Only the Internet address format is currently understood.
Standards compliance
gethostbyname, gethostbyname2
and gethostbyaddr are conformant with:
RFC1034 (STD13), RFC1035 (STD13)
30 January 1998
© 1998 The Santa Cruz Operation, Inc. All rights reserved.