Skip to main content

Python client for Consul (http://www.consul.io/)

Project description

py-consul PyPi version Python version Status

Status

This project is maintained and actively developed by Criteo. We aim at converging towards a full compatibility with the official Consul API.

We're currently supporting consul 1.20 up to 1.22. Due to quite a few changes since our development started (see section "A bit of history"), some endpoints are still partially handled.

Therefore, we are open to contributions and suggestions.

Example

    import consul

    c = consul.Consul()

    # poll a key for updates
    index = None
    while True:
        index, data = c.kv.get('foo', index=index)
        print data['Value']

    # in another process
    c.kv.put('foo', 'bar')

Installation

    pip install py-consul

Note: When using py-consul library in environment with proxy server, setting of http_proxy, https_proxy and no_proxy environment variables can be required for proper functionality.

A bit of history

The origin project python-consul is not maintained since 2018. As we were not able to get in touch with the maintainer (cablehead) to merge and release our PRs, we've forked the project in order to continue the maintenance of the project. We also renamed the project to be able to upload on pypi; see PyPI

Following some major changes, we decided to detach this fork from the original project and move from criteo fork space to criteo space.

Contributing

Please reach out if you're interested in being a maintainer as well. Otherwise, open a PR or Issue we'll try and respond as quickly as possible.

When you create a PR please ensure:

  • To add tests for your new features, if applicable
  • To add docstrings for new API features you may add

Change log

Since version 1.5.6, please refer to Releases

1.5.5

  • fix: Simplify loop handling in async Consul client

1.5.4

  • feature: Improve robustness of JSON decoding
  • feature: Add support for honoring additional arguments in consul.Consul()

1.5.3

  • feature: add replace_existing_checks option to agent.service.register()
  • revert: add replace_existing_checks option to Catalog.register()

1.5.2

  • feature: add replace_existing_checks option to Catalog.register()

1.5.1

  • feature: Implement creation of policies.
  • feature: Integrate policy addition during token creation.

1.5.0

  • [Breaking] ACL endpoint change, consul.acl is now consul.acl.token
  • feature: add consul.acl.policy.list and acl.policy.read

1.4.1

  • ci: fix package publishing and update GH actions versions

1.4.0 (unreleased)

  • [Breaking] due to the re-implementation of the ACL endpoint and the drop of the support of OSX and consul 1.1.0.
    • feature: re-implement some basic ACL endpoint
    • feature: drop support of OSX and consul 1.1.0
    • feature: support multi-check service registration (through extra_checks parameter)
    • env: support python 3.12
    • tests: multi consul version test (1.13.8, 1.15.4, 1.16.1, 1.17.3)
    • tests: add test utils for cleaner API output expected assertion
    • code-style: use ruff linter and formatter
    • code-style: split files following the consul API logic
    • ci: speedup ci with uv/tox-uv

1.3.0

  • feature: drop tornado and twisted support
  • env: support python 3.10 and 3.11
  • env: drop support of EOL python versions 3.5, 3.6, and 3.7
  • code-style: syntax modernization
  • code-style: formatter and linter use
  • ci: multiple python version test and linter enforcement

1.2.4

  • feature: aio: allow setting timeout by request

1.2.3

  • feature: base: ensure return format of json callback is more consistent

1.2.2

  • bugfix: connect: fix wrong endpoints callbacks

1.2.1

  • feature: Add support for context-managers
  • feature: Add support for /agent/service/:service_id API
  • bugfix: rename internal connect method

1.2.0

  • feature: Support deregister field in Check.script
  • feature: Introduce Consul Connect-related API wrappers
  • feature: Add token support missing in multiple methods
  • bugfix: aio: fix timeout type
  • feature: allow multiple tags in service health query

1.1.5

  • Dummy release to overcome a pypi release issue

1.1.4

  • bugfix: fixed connection_timeout usage for aiohttp

1.1.3

  • bugfix: fixed connection_limit usage for aiohttp

1.1.2

  • add support for connection_limit and connection_timeout in aiohttp
  • fix asyncio session close

1.1.1

  • Add support for python 3.7 and 3.8
  • Fix asyncio compatibility to support latest python version
  • Remove six dependency
  • Use new style of class declaration
  • Get rid of py3.4 old compat
  • Drop support of deprecated python2
  • base: allow weights parameter in service register

Base fork

Criteo starts forking this library from https://github.com/cablehead/python-consul

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

py_consul-1.7.1.tar.gz (36.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

py_consul-1.7.1-py2.py3-none-any.whl (38.7 kB view details)

Uploaded Python 2Python 3

File details

Details for the file py_consul-1.7.1.tar.gz.

File metadata

  • Download URL: py_consul-1.7.1.tar.gz
  • Upload date:
  • Size: 36.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for py_consul-1.7.1.tar.gz
Algorithm Hash digest
SHA256 a0b3912a0af449e1cd09c4aa710e53d1149c5edb3512a1becbe6475ed395761a
MD5 af83a2e9bee61ff74da8061fbdf23318
BLAKE2b-256 979386604f8fd9bbbfe60ea80a2d17d4dfb2fd3e32c7af736d789cf72587e1f6

See more details on using hashes here.

File details

Details for the file py_consul-1.7.1-py2.py3-none-any.whl.

File metadata

  • Download URL: py_consul-1.7.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 38.7 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for py_consul-1.7.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 016fe49c65c68426e1c0353de2243865fd58e3c7a940413b6202c2becf3cfb04
MD5 61be513ea10fa65075299f496b03d62d
BLAKE2b-256 fbc9e8ed59e6d24c0972aa8be9e2a288ba096c7e7fc21739a296b624da7a4aa6

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page