pycares

Python interface for c-ares

47 个版本 Python >=3.9
安装
pip install pycares
poetry add pycares
pipenv install pycares
conda install pycares
描述

pycares: Python interface for c-ares

pycares is a Python module which provides an interface to c-ares. c-ares <https://c-ares.org>_ is a C library that performs DNS requests and name resolutions asynchronously.

Documentation

http://readthedocs.org/docs/pycares/

Bundled c-ares

pycares currently bundles c-ares as a submodule for ease of building. Using the system provided c-ares is possible if the PYCARES_USE_SYSTEM_LIB environment variable is set to 1 when building.

NOTE: Versions prior to 4.0.0 used to embed a modified c-ares with extended TTL support. That is no longer the case and as a result only A and AAAA records will have TTL information. Follow this PR in uppstream c-ares, looks like TTLs will be added: https://github.com/c-ares/c-ares/pull/393

Installation

GNU/Linux, macOS, Windows, others:

::

pip install pycares

FreeBSD:

::

cd /usr/ports/dns/py-pycares && make install

IDNA 2008 support ^^^^^^^^^^^^^^^^^

If the idna package is installed, pycares will support IDNA 2008 encoding otherwise the builtin idna codec will be used, which provides IDNA 2003 support.

You can force this at installation time as follows:

::

pip install pycares[idna]

Running the test suite

From the top level directory, run: python -m unittest -v

NOTE: Running the tests requires internet access and are somewhat environment sensitive because real DNS queries are made, there is no mocking. If you observe a failure that the CI cannot reproduce, please try to setup an environment as close as the current CI.

Using it from the cli, a la dig

This module can be used directly from the command line in a similar fashion to dig (limited, of course):

::

$ python -m pycares google.com ;; QUESTION SECTION: ;google.com IN A

;; ANSWER SECTION: google.com 300 IN A 172.217.17.142

$ python -m pycares mx google.com ;; QUESTION SECTION: ;google.com IN MX

;; ANSWER SECTION: google.com 600 IN MX 50 alt4.aspmx.l.google.com google.com 600 IN MX 10 aspmx.l.google.com google.com 600 IN MX 40 alt3.aspmx.l.google.com google.com 600 IN MX 20 alt1.aspmx.l.google.com google.com 600 IN MX 30 alt2.aspmx.l.google.com

Author

Saúl Ibarra Corretgé s@saghul.net

License

Unless stated otherwise on-file pycares uses the MIT license, check LICENSE file.

Supported Python versions

Python >= 3.9 are supported. Both CPython and PyPy are supported.

Contributing

If you'd like to contribute, fork the project, make a patch and send a pull request. Have a look at the surrounding code and please, make yours look alike.

版本列表
5.0.1 2026-01-01
5.0.0 2025-12-10
4.11.0 2025-09-09
4.10.0 2025-08-05
4.9.0 2025-06-13
4.8.0 2025-05-04
4.7.0 2025-05-02
4.6.1 2025-04-20
4.6.0 2025-04-04
4.5.0 2024-11-26
4.4.0 2023-10-06
4.3.0 2022-12-10
4.2.2 2022-08-09
4.2.1 2022-06-28
4.2.0 2022-06-21
4.1.2 2021-10-18
4.1.1 2021-10-18
4.0.0 2021-05-13
3.2.3 2021-05-11
3.2.0 2021-05-11
3.1.1 2020-01-09
3.1.0 2019-12-12
3.0.0 2019-03-02
3.0.0b5 2019-02-14
3.0.0b4 2019-02-05
3.0.0b3 2019-01-23
3.0.0b2 2019-01-17
3.0.0b1 2019-01-17
3.0.0b0 2019-01-16
2.4.0 2019-01-02
2.3.0 2017-07-20
2.2.0 2017-07-08
2.1.1 2016-10-03
2.1.0 2016-06-14
2.0.1 2016-05-28
2.0.0 2016-05-25
1.0.0 2015-09-01
0.7.0 2015-04-17
0.6.3 2014-08-30
0.6.2 2014-07-28
0.6.1 2014-04-05
0.6.0 2014-03-26
0.5.0 2013-05-13
0.4.0 2012-11-26
0.3.0 2012-08-21
0.2.0 2012-08-14
0.1.0 2012-07-09