Skip to main content

A small, modular, transport and protocol neutral RPC library that, among other things, supports JSON-RPC and zmq.

Project description

https://readthedocs.org/projects/tinyrpc/badge/?version=latest https://github.com/mbr/tinyrpc/actions/workflows/python-tox.yml/badge.svg https://badge.fury.io/py/tinyrpc.svg

Note

Tinyrpc has been revised.

The current version will support Python3 only. Have a look at the 0.9.x version if you need Python2 support. Python2 support will be dropped completely when Python2 retires, somewhere in 2020.

Motivation

As of this writing (in Jan 2013) there are a few jsonrpc libraries already out there on PyPI, most of them handling one specific use case (e.g. json via WSGI, using Twisted, or TCP-sockets).

None of the libraries, however, makes it easy to reuse the jsonrpc-parsing bits and substitute a different transport (i.e. going from json via TCP to an implementation using WebSockets or 0mq).

In the end, all these libraries have their own dispatching interfaces and a custom implementation of handling jsonrpc. Today (march 2019) that hasn’t changed.

tinyrpc aims to do better by dividing the problem into cleanly interchangeable parts that allow easy addition of new transport methods, RPC protocols or dispatchers.

Example:

To create a server process receiving and handling JSONRPC requests do:

import gevent
import gevent.pywsgi
import gevent.queue
from tinyrpc.protocols.jsonrpc import JSONRPCProtocol
from tinyrpc.transports.wsgi import WsgiServerTransport
from tinyrpc.server.gevent import RPCServerGreenlets
from tinyrpc.dispatch import RPCDispatcher

dispatcher = RPCDispatcher()
transport = WsgiServerTransport(queue_class=gevent.queue.Queue)

# start wsgi server as a background-greenlet
wsgi_server = gevent.pywsgi.WSGIServer(('127.0.0.1', 5000), transport.handle)
gevent.spawn(wsgi_server.serve_forever)

rpc_server = RPCServerGreenlets(transport, JSONRPCProtocol(), dispatcher)

@dispatcher.public
def reverse_string(s):
    return s[::-1]

# in the main greenlet, run our rpc_server
rpc_server.serve_forever()

The corresponding client code looks like:

from tinyrpc.protocols.jsonrpc import JSONRPCProtocol
from tinyrpc.transports.http import HttpPostClientTransport
from tinyrpc import RPCClient

rpc_client = RPCClient(
    JSONRPCProtocol(),
    HttpPostClientTransport('http://127.0.0.1:5000/'))

remote_server = rpc_client.get_proxy()

# call a method called 'reverse_string' with a single string argument
result = remote_server.reverse_string('Hello, World!')

print("Server answered:", result)

Documentation

You’ll quickly find that tinyrpc has more documentation and tests than core code, hence the name. See the documentation at <https://tinyrpc.readthedocs.org> for more details, especially the Structure-section to get a birds-eye view.

Installation

pip install tinyrpc

will install tinyrpc with its default dependencies.

Optional dependencies

Depending on the protocols and transports you want to use additional dependencies are required. You can instruct pip to install these dependencies by specifying extras to the basic install command.

pip install tinyrpc[httpclient, wsgi]

will install tinyrpc with dependencies for the httpclient and wsgi transports.

Available extras are:

Option

Needed to use objects of class

gevent

optional in RPCClient, required by RPCServerGreenlets

httpclient

HttpPostClientTransport, HttpWebSocketClientTransport

msgpack

implements MSGPACKRPCProtocol

jsonext

optional in JSONRPCProtocol

rabbitmq

RabbitMQServerTransport, RabbitMQClientTransport

websocket

WSServerTransport

wsgi

WsgiServerTransport

zmq

ZmqServerTransport, ZmqClientTransport

New in version 1.1.0

Tinyrpc supports RabbitMQ has transport medium.

New in version 1.0.4

Tinyrpc now supports the MSGPACK RPC protocol in addition to JSON-RPC.

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

tinyrpc-1.1.7.tar.gz (40.2 kB view details)

Uploaded Source

Built Distribution

tinyrpc-1.1.7-py3-none-any.whl (52.3 kB view details)

Uploaded Python 3

File details

Details for the file tinyrpc-1.1.7.tar.gz.

File metadata

  • Download URL: tinyrpc-1.1.7.tar.gz
  • Upload date:
  • Size: 40.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 colorama/0.4.6 importlib-metadata/6.8.0 keyring/23.5.0 pkginfo/1.8.2 readme-renderer/34.0 requests-toolbelt/0.9.1 requests/2.25.1 rfc3986/1.5.0 tqdm/4.57.0 urllib3/1.26.5 CPython/3.10.6

File hashes

Hashes for tinyrpc-1.1.7.tar.gz
Algorithm Hash digest
SHA256 15a8f41838e7b8be274467de59ad5c571e4cb5a2fe93bc2940b1d103bce4c6e5
MD5 b5079a23bbd8c41a33fe15c7486acf3e
BLAKE2b-256 6a31b0d0403cafda7965fab0741bcb7c63b26eab7fcfb605d4ece31a6f7b034d

See more details on using hashes here.

Provenance

File details

Details for the file tinyrpc-1.1.7-py3-none-any.whl.

File metadata

  • Download URL: tinyrpc-1.1.7-py3-none-any.whl
  • Upload date:
  • Size: 52.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 colorama/0.4.6 importlib-metadata/6.8.0 keyring/23.5.0 pkginfo/1.8.2 readme-renderer/34.0 requests-toolbelt/0.9.1 requests/2.25.1 rfc3986/1.5.0 tqdm/4.57.0 urllib3/1.26.5 CPython/3.10.6

File hashes

Hashes for tinyrpc-1.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 59f67cd03d42c5d0d2471dd75ac7f1470f53665e92cdba02eecd13ea27cdec70
MD5 5da337be4c3328e4095c1e7a78df3476
BLAKE2b-256 22a0ca9f00c05633e7c2d8f84d4b6ed2ec4640a19802974a3218c9ba3239b543

See more details on using hashes here.

Provenance

Supported by

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