简单的PRC和Protobuf服务

hyper-rpc的Python项目详细描述


超级rpc

Build Status

带Protobuf服务的简单RPC

在引擎盖下使用grpcio_toolspurerpc。在

安装

$ pip install hyper-rpc

示例

TLDR; See the example directory

greeter.proto中定义RPC服务。在

^{pr2}$

然后使用hyper-rpc生成服务和存根。在

$ pip install hyper-rpc
$ hrpc greeter.proto

这将创建greeter_gprc.py(服务)和greeter_pb2.py(存根)文件。在

然后可以编写一个异步就绪服务器。在

"""Greeter server."""fromgreeter_grpcimportGreeterServicerfromgreeter_pb2importHelloReply,HelloRequestfrompurerpcimportServerclassGreeter(GreeterServicer):asyncdefSayHello(self,message):returnHelloReply(message=f"Hello {message.name}")asyncdefSayHelloToMany(self,input_messages):asyncformessageininput_messages:yieldHelloReply(message=f"Hello, {message.name}")if__name__=="__main__":server=Server(50055)server.add_service(Greeter().service)server.serve(backend="trio")

还有一个客户。在

"""Greeter client."""importanyioimportpurerpcfromgreeter_grpcimportGreeterStubfromgreeter_pb2importHelloReply,HelloRequestasyncdefgen():foriinrange(5):yieldHelloRequest(name=str(i))asyncdefmain():asyncwithpurerpc.insecure_channel("localhost",50055)aschannel:stub=GreeterStub(channel)reply=awaitstub.SayHello(HelloRequest(name="World"))print(reply.message)asyncforreplyinstub.SayHelloToMany(gen()):print(reply.message)if__name__=="__main__":anyio.run(main,backend="trio")

并在不同的终端上运行以查看输出。在

$ python server.py # terminal 1
$ python client.py # terminal 2

输出:

Hello, World
Hello, 0
Hello, 1
Hello, 2
Hello, 3
Hello, 4

向前走Remote Procedure Call。在

The person who invented the term RPC

欢迎加入QQ群-->: 979659372 Python中文网_新手群

推荐PyPI第三方库


热门话题
java编辑并重新运行spring引导单元测试,无需重新加载上下文即可加快测试速度   为什么我不能做演员?   java为什么是线程。join通常用于停止安卓中的线程   java从weblogic服务器调用JSON POST REST服务时收到400:错误请求   java在DeviceAdmin模式禁用时设置身份验证?   java SortedMap的keySet()能否始终安全地强制转换到SortedSet?   安卓 java。lang.NoSuchMethodException可包裹类   java JOGL库安装   javatomcat内存管理   java使用getString()中的变量   java将最小星号设置为评级栏   Java中字符串相等的println()方法。。。它到底是如何工作的?   java如何从文本中输出的数组中放入随机图像