Skip to main content

A Python library for microservice registry and executing RPC (Remote Procedure Call) over Redis

Project description

Inventa for Python

LinkedIn Twitter HitCount License

A Python library for microservice registry and executing RPC (Remote Procedure Call) over Redis.

WHY THIS PROJECT?

Service discovery, registry, and execution of remote procedures are some of the necessary tools in distributed applications. You must track which services (also how many replica instances of them) are alive. Also, your services should communicate between each other (choreography) or via an orchestrator service on top of them.

You can do API/function calls remotely by serving REST APIs, gRPC endpoints, etc... But these choices came with some drawbacks or advantages, you have lots of different architectural options on this topic.

Inventa offers you a lightweight solution for these requirements; if you already have Redis in your project's toolbox, and if all of your services have access to this Redis instance.

Also, Inventa doesn't abstract/hide its Redis client object, you can use its Redis Client object freely which is already connected to the server.

USAGE SCENARIO

  • You have an application that consists of multiple services, developed with different languages (currently Go and Python are supported),
  • These services exist for different jobs, also they may be replicated into more than one instances, may be run in either different containers or machines,
  • There is one registrar/orchestrator service which other services will register themselves and send their heartbeats to it,
  • The orchestrator knows which service types and instances are alive now, the orchestrator should select one of the instances of a specific service, then call a function/procedure of the service, and get a response remotely.
  • All of your services will use Inventa, the one orchestrator service will instantiate it in Orchestrator Inventa role, other services will instantiate it in Service Inventa role.
  • Both Service roles and the Orchestrator role can call functions that are provided by other services if they know target service's identifier.

INSTALLATION

pip install inventa

EXAMPLE PROJECT

You can find example projects made using Inventa at https://github.com/adalkiran/inventa-examples.

OTHER IMPLEMENTATIONS

You can find Go implementation of Inventa on Inventa for Go (go-inventa).

LICENSE

Inventa for Python is licensed under the Apache License, Version 2.0. See LICENSE for the full license text.

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

inventa-0.0a15.tar.gz (12.7 kB view details)

Uploaded Source

Built Distribution

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

inventa-0.0a15-py3-none-any.whl (15.2 kB view details)

Uploaded Python 3

File details

Details for the file inventa-0.0a15.tar.gz.

File metadata

  • Download URL: inventa-0.0a15.tar.gz
  • Upload date:
  • Size: 12.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.13

File hashes

Hashes for inventa-0.0a15.tar.gz
Algorithm Hash digest
SHA256 43bc846617f33db51ea51fed123bd8554c83ed68ed7c12fe1b371e59869f44ac
MD5 add8e08a2119c1fdd27b69e0ff217228
BLAKE2b-256 ac21f5fb4b68ed39b3c7dc751fb19a3f367728167bff24f27dc999a91bb0264d

See more details on using hashes here.

File details

Details for the file inventa-0.0a15-py3-none-any.whl.

File metadata

  • Download URL: inventa-0.0a15-py3-none-any.whl
  • Upload date:
  • Size: 15.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.13

File hashes

Hashes for inventa-0.0a15-py3-none-any.whl
Algorithm Hash digest
SHA256 b5c87d0b059c718eecec2be6f7b8cf97c3c7024711da0f80380fab3201fbd496
MD5 c696ae8aac9573d312f272c087c6c87e
BLAKE2b-256 ab97b04dd1d1b1ef593a438084702ce3b76338f5acc6ccd37ca592bab8b66e50

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