A C library for asynchronous DNS requests (grpc依赖)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Daniel Stenberg cfa535b3a5 Introducing ares_version(), so that we can have apps get version info about 21 years ago
vc ares 1.1.1 with collected applied patches 21 years ago
.cvsignore ignore these too 21 years ago
CHANGES name it pre1 21 years ago
FILES added for completeness 21 years ago
Makefile.in Introducing ares_version(), so that we can have apps get version info about 21 years ago
NEWS ares 1.1.1 with collected applied patches 21 years ago
README ares 1.1.1 with collected applied patches 21 years ago
aclocal.m4 ares 1.1.1 with collected applied patches 21 years ago
adig.c ares 1.1.1 with collected applied patches 21 years ago
ahost.c ares 1.1.1 with collected applied patches 21 years ago
ares.h ares 1.1.1 with collected applied patches 21 years ago
ares__close_sockets.c ares 1.1.1 with collected applied patches 21 years ago
ares__get_hostent.c ares 1.1.1 with collected applied patches 21 years ago
ares__read_line.c ares 1.1.1 with collected applied patches 21 years ago
ares_destroy.3 ares 1.1.1 with collected applied patches 21 years ago
ares_destroy.c ares 1.1.1 with collected applied patches 21 years ago
ares_dns.h ares 1.1.1 with collected applied patches 21 years ago
ares_expand_name.3 ares 1.1.1 with collected applied patches 21 years ago
ares_expand_name.c ares 1.1.1 with collected applied patches 21 years ago
ares_fds.3 ares 1.1.1 with collected applied patches 21 years ago
ares_fds.c ares 1.1.1 with collected applied patches 21 years ago
ares_free_errmem.3 ares 1.1.1 with collected applied patches 21 years ago
ares_free_errmem.c ares 1.1.1 with collected applied patches 21 years ago
ares_free_hostent.3 ares 1.1.1 with collected applied patches 21 years ago
ares_free_hostent.c ares 1.1.1 with collected applied patches 21 years ago
ares_free_string.3 ares 1.1.1 with collected applied patches 21 years ago
ares_free_string.c ares 1.1.1 with collected applied patches 21 years ago
ares_gethostbyaddr.3 ares 1.1.1 with collected applied patches 21 years ago
ares_gethostbyaddr.c ares 1.1.1 with collected applied patches 21 years ago
ares_gethostbyname.3 ares 1.1.1 with collected applied patches 21 years ago
ares_gethostbyname.c ares 1.1.1 with collected applied patches 21 years ago
ares_init.3 ares 1.1.1 with collected applied patches 21 years ago
ares_init.c ares 1.1.1 with collected applied patches 21 years ago
ares_init_options.3 ares 1.1.1 with collected applied patches 21 years ago
ares_mkquery.3 ares 1.1.1 with collected applied patches 21 years ago
ares_mkquery.c ares 1.1.1 with collected applied patches 21 years ago
ares_parse_a_reply.3 ares 1.1.1 with collected applied patches 21 years ago
ares_parse_a_reply.c ares 1.1.1 with collected applied patches 21 years ago
ares_parse_ptr_reply.3 ares 1.1.1 with collected applied patches 21 years ago
ares_parse_ptr_reply.c ares 1.1.1 with collected applied patches 21 years ago
ares_private.h ares 1.1.1 with collected applied patches 21 years ago
ares_process.3 ares 1.1.1 with collected applied patches 21 years ago
ares_process.c ares 1.1.1 with collected applied patches 21 years ago
ares_query.3 ares 1.1.1 with collected applied patches 21 years ago
ares_query.c ares 1.1.1 with collected applied patches 21 years ago
ares_search.3 ares 1.1.1 with collected applied patches 21 years ago
ares_search.c ares 1.1.1 with collected applied patches 21 years ago
ares_send.3 ares 1.1.1 with collected applied patches 21 years ago
ares_send.c ares 1.1.1 with collected applied patches 21 years ago
ares_strerror.3 ares 1.1.1 with collected applied patches 21 years ago
ares_strerror.c ares 1.1.1 with collected applied patches 21 years ago
ares_timeout.3 ares 1.1.1 with collected applied patches 21 years ago
ares_timeout.c ares 1.1.1 with collected applied patches 21 years ago
ares_version.c Introducing ares_version(), so that we can have apps get version info about 21 years ago
ares_version.h Introducing ares_version(), so that we can have apps get version info about 21 years ago
config.guess ares 1.1.1 with collected applied patches 21 years ago
config.sub ares 1.1.1 with collected applied patches 21 years ago
configure.in ares 1.1.1 with collected applied patches 21 years ago
install-sh added for completeness 21 years ago
maketgz run autoconf if needed 21 years ago
mkinstalldirs added for completeness 21 years ago
nameser.h ares 1.1.1 with collected applied patches 21 years ago
windows_port.c ares 1.1.1 with collected applied patches 21 years ago

README

This is ares, an asynchronous resolver library.  It is intended for
applications which need to perform DNS queries without blocking, or
need to perform multiple DNS queries in parallel. The primary
examples of such applications are servers which communicate with
multiple clients and programs with graphical user interfaces.

This library implementation is not especially portable to crufty old
systems like SunOS 4. It assumes a compiler which can handle ANSI C
syntax, a system malloc which properly handles realloc(NULL, foo) and
free(NULL), and a reasonably up-to-date <arpa/nameser.h>.

I have attempted to preserve the externally visible behavior of the
BIND resolver in nearly all respects. The API of the library is, of
course, very different from the synchronous BIND API; instead of
invoking a function like res_send() and getting a return value back
indicating the number of bytes in the response, you invoke a function
like ares_send() and give it a callback function to invoke when the
response arrives. You then have to select() on the file descriptors
indicated by ares_fds(), with a timeout given by ares_timeout(). You
call ares_process() when select() returns.

Some features are missing from the current version of ares, relative
to the BIND resolver:

* There is no IPV6 support.
* There is no hostname verification.
* There is no logging of unexpected events.
* There is no debugging-oriented logging.
* There is no YP support.

libares requires an ANSI compiler to compile and use. To build the
library, just run "./configure" and "make". To install it, run "make
install". Run "./configure --help" to see a list of options you can
provide to configure to change how the library builds. libares has no
data files, so you can move the include file and library around freely
without leaving behind any dependencies on old paths. Building the
library will also build the "adig" program, a little toy for trying
out the library. It doesn't get installed.

libares is distributed at athena-dist.mit.edu:pub/ATHENA/ares. Please
send bug reports and comments to ghudson@mit.edu.