{ "info": { "author": "Cholerae Hu", "author_email": "choleraehyq@gmail.com", "bugtrack_url": null, "classifiers": [], "description": " Copyright (C) 2016 Cholerae hu \n\n Everyone is permitted to copy and distribute verbatim or modified\n copies of this license document, and changing it is allowed as long\n as the name is changed.\n\n DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE\n TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION\n\n 0. You just DO WHAT THE FUCK YOU WANT TO.\nDescription: aiorpc\n ======\n \n .. image:: https://badge.fury.io/py/aiorpc.png\n :target: http://badge.fury.io/py/aiorpc\n \n .. image:: https://travis-ci.org/choleraehyq/aiorpc.png?branch=master\n :target: https://travis-ci.org/choleraehyq/aiorpc\n \n aiorpc is a lightweight asynchronous RPC library. It enables you to easily build a distributed server-side system by writing a small amount of code. It is built on top of `asyncio `_ and `MessagePack `_.\n \n \n Installation\n ------------\n \n To install aiorpc, simply:\n \n .. code-block:: bash\n \n $ pip install aiorpc\n \n Examples\n --------\n \n RPC server\n ^^^^^^^^^^\n \n .. code-block:: python\n \n from aiorpc import register, serve\n \n import asyncio\n import uvloop\n \n \n def echo(msg):\n return msg\n \n loop = uvloop.new_event_loop()\n asyncio.set_event_loop(loop)\n register(\"echo\", echo)\n coro = asyncio.start_server(serve, '127.0.0.1', 6000, loop=loop)\n server = loop.run_until_complete(coro)\n \n try:\n loop.run_forever()\n except KeyboardInterrupt:\n server.close()\n loop.run_until_complete(server.wait_closed())\n \n RPC client\n ^^^^^^^^^^\n \n .. code-block:: python\n \n from aiorpc import RPCClient\n \n import asyncio\n import uvloop\n \n async def do(cli):\n ret = await client.call('echo', 'message')\n print(\"{}\\n\".format(ret))\n \n loop = uvloop.new_event_loop()\n asyncio.set_event_loop(loop)\n client = RPCClient('127.0.0.1', 6000)\n loop.run_until_complete(do(client))\n client.close()\n \n Performance\n -----------\n \n aiorpc with `uvloop `_ significantly outperforms `ZeroRPC `_ (**6x** faster), which is built using `ZeroMQ `_ and `MessagePack `_ and slightly underperforms `official MessagePack RPC `_ (**0.7x** slower), which is built using `Facebook's Tornado `_ and `MessagePack `_.\n \n - aiorpc\n \n \n .. code-block:: bash\n \n % python benchmarks/benchmark_aiorpc.py\n call: 2236 qps\n \n \n - Official MesssagePack RPC\n \n .. code-block:: bash\n \n % pip install msgpack-rpc-python\n % python benchmarks/benchmark_msgpackrpc.py\n call: 3112 qps\n \n - ZeroRPC\n \n .. code-block:: bash\n \n % pip install zerorpc\n % python benchmarks/benchmark_zerorpc.py\n call: 351 qps\n \n \n Documentation\n -------------\n \n Documentation is available at http://aiorpc.readthedocs.org/.\n (Since readthedocs don't support Python 3.5 yet, this page is unavailable now.)\n \nKeywords: rpc,msgpack,messagepack,msgpackrpc,messagepackrpc,asyncio\nPlatform: UNKNOWN\nClassifier: Development Status :: 4 - Beta\nClassifier: Intended Audience :: Developers\nClassifier: Natural Language :: English\nClassifier: Programming Language :: Python\nClassifier: Programming Language :: Python :: 3.5\n", "description_content_type": "", "docs_url": null, "download_url": "", "downloads": { "last_day": -1, "last_month": -1, "last_week": -1 }, "home_page": "http://github.com/choleraehyq/aiorpc", "keywords": "", "license": "DO WHAT THE FUCK YOU WANT TO PUBLIC LICENSE Version 2, December 2004", "maintainer": "", "maintainer_email": "", "name": "aiorpc", "package_url": "https://pypi.org/project/aiorpc/", "platform": "", "project_url": "https://pypi.org/project/aiorpc/", "project_urls": { "Homepage": "http://github.com/choleraehyq/aiorpc" }, "release_url": "https://pypi.org/project/aiorpc/0.1.3/", "requires_dist": [ "msgpack-python", "uvloop" ], "requires_python": "", "summary": "A fast RPC library based on asyncio and MessagePack", "version": "0.1.3" }, "last_serial": 3857828, "releases": { "0.1.2": [ { "comment_text": "", "digests": { "md5": "a6e978de3ff78e24a1d97e4eeefc2e6a", "sha256": "d1b66e4140fd0d0450d71bd910062e01d0e72ca24cf79ef1353cae9280ae6a7d" }, "downloads": -1, "filename": "aiorpc-0.1.2-py3-none-any.whl", "has_sig": false, "md5_digest": "a6e978de3ff78e24a1d97e4eeefc2e6a", "packagetype": "bdist_wheel", "python_version": "py3", "requires_python": null, "size": 8832, "upload_time": "2018-05-13T03:32:33", "url": "https://files.pythonhosted.org/packages/28/3d/756344c4907908f5a12f85927a4348a0863d8334d5f140572f85ab0f5458/aiorpc-0.1.2-py3-none-any.whl" }, { "comment_text": "", "digests": { "md5": "6440dc39dfdb7e994dc178419ef7aac7", "sha256": "b1e8ebbe9169b8565edbb38f18f17cf55badb2fd87dca154a8f42c8d9dc5b1b0" }, "downloads": -1, "filename": "aiorpc-0.1.2.tar.gz", "has_sig": false, "md5_digest": "6440dc39dfdb7e994dc178419ef7aac7", "packagetype": "sdist", "python_version": "source", "requires_python": null, "size": 6667, "upload_time": "2016-10-08T09:35:44", "url": "https://files.pythonhosted.org/packages/88/e6/64d66f5f9c3b95a75e2ae7ebbad0f0f9af97c15ec1c0f10df73b2c28987d/aiorpc-0.1.2.tar.gz" } ], "0.1.3": [ { "comment_text": "", "digests": { "md5": "25d458d91d78311c9c85ac55c3c32185", "sha256": "3140504ff143eb5b55fed86b8fdd00c5862e15126595dcef20087ba7b3d57ccd" }, "downloads": -1, "filename": "aiorpc-0.1.3-py3-none-any.whl", "has_sig": false, "md5_digest": "25d458d91d78311c9c85ac55c3c32185", "packagetype": "bdist_wheel", "python_version": "py3", "requires_python": null, "size": 8834, "upload_time": "2018-05-13T03:32:35", "url": "https://files.pythonhosted.org/packages/e0/22/6f9dce9362c881a8cab566a1a1b51e5859927a741f93d58ce97419e61991/aiorpc-0.1.3-py3-none-any.whl" } ] }, "urls": [ { "comment_text": "", "digests": { "md5": "25d458d91d78311c9c85ac55c3c32185", "sha256": "3140504ff143eb5b55fed86b8fdd00c5862e15126595dcef20087ba7b3d57ccd" }, "downloads": -1, "filename": "aiorpc-0.1.3-py3-none-any.whl", "has_sig": false, "md5_digest": "25d458d91d78311c9c85ac55c3c32185", "packagetype": "bdist_wheel", "python_version": "py3", "requires_python": null, "size": 8834, "upload_time": "2018-05-13T03:32:35", "url": "https://files.pythonhosted.org/packages/e0/22/6f9dce9362c881a8cab566a1a1b51e5859927a741f93d58ce97419e61991/aiorpc-0.1.3-py3-none-any.whl" } ] }