Chinaunix首页 | 论坛 | 博客
  • 博客访问: 187537
  • 博文数量: 60
  • 博客积分: 1597
  • 博客等级: 上尉
  • 技术积分: 461
  • 用 户 组: 普通用户
  • 注册时间: 2008-11-20 13:24
文章分类

全部博文(60)

文章存档

2017年(15)

2016年(6)

2015年(37)

2008年(2)

分类: Python/Ruby

2017-10-18 10:16:57

pip install grpcio
pip install protobuf
pip install grpcio-tools

data.proto:
syntax = 'proto3';
// 服务定义
service data{
    // 函数定义 data_request参数 data_reply返回数据
    rpc serving(data_request) returns (data_reply) {}
}
message data_request{
    string cmd= 1;
}
message data_reply{
    string values = 1;
}

python -m grpc_tools.protoc -I. --python_out=../ --grpc_python_out=../ ./data.proto

data_server.py:
import data_pb2
import data_pb2_grpc
import grpc
from concurrent import futures
import time

class ServerGreeter(data_pb2_grpc.dataServicer):
    def serving(self, request, context):
        print('serving:', request.cmd)
        f = open('./a.jpg', 'rb')
        img_64 = base64.b64encode(f.read())
        f.close()
        return data_pb2.data_reply(values=img_64)


def serve():
    server = grpc.server(futures.ThreadPoolExecutor(max_workers=10))
    data_pb2_grpc.add_dataServicer_to_server(ServerGreeter(), server)
    server.add_insecure_port('[::]:5001')
    server.start()
    try:
        while True:
            time.sleep(60 * 60 * 24)
    except KeyboardInterrupt:
        server.stop(0)

if __name__ == '__main__':
    serve()

data_client.py:
import data_pb2
import data_pb2_grpc
import grpc

def run():
    channel = grpc.insecure_channel('127.0.0.1:5001')
    stub = data_pb2_grpc.dataStub(channel)
    response = stub.serving(data_pb2.data_request(cmd='abc'))
    imgf = base64.b64decode(response.values)
    f = open('./b.jpg', 'wb')
    f.write(imgf)
    f.close()


if __name__ == '__main__':
    run()

阅读(2107) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~