Compartilhamento de tecnologia

[Python] Projeto simples Python Flask e gRPC

2024-07-12

한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina

Projetos de amostra Python Flask e gRPC

Este artigo apresentará como criar um aplicativo de exemplo simples usando Flask e gRPC em Python e usar requests biblioteca para testes.

Configurações de ambiente

Primeiro, certifique-se de ter o Python instalado. Em seguida, crie um ambiente virtual para gerenciar suas dependências.

python -m venv myenv
source myenv/bin/activate  # Windows 使用 `myenvScriptsactivate`
  • 1
  • 2

Instale os pacotes necessários:

pip install Flask grpcio grpcio-tools requests
  • 1

Definir serviço gRPC

Criar .proto arquivo para definir o serviço gRPC.Salvar nome do arquivoservice.proto

syntax = "proto3";

package demo;

service DemoService {
  rpc SayHello (HelloRequest) returns (HelloResponse) {}
}

message HelloRequest {
  string name = 1;
}

message HelloResponse {
  string message = 1;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

Gere código Python a partir de arquivos Proto

usar grpc_tools Gere código Python:

python -m grpc_tools.protoc -I. --python_out=. --grpc_python_out=. service.proto
  • 1

Isso irá gerar dois arquivos:service_pb2.py eservice_pb2_grpc.py

Implementar servidor gRPC

Crie um arquivo chamado grpc_server.py documento:

from concurrent import futures
import grpc
import service_pb2
import service_pb2_grpc

class DemoService(service_pb2_grpc.DemoServiceServicer):
    def SayHello(self, request, context):
        return service_pb2.HelloResponse(message=f'Hello, {request.name}!')

def serve():
    server = grpc.server(futures.ThreadPoolExecutor(max_workers=10))
    service_pb2_grpc.add_DemoServiceServicer_to_server(DemoService(), server)
    server.add_insecure_port('[::]:50051')
    server.start()
    print("gRPC server started on port 50051")
    server.wait_for_termination()

if __name__ == '__main__':
    serve()
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19

Implementar servidor Flask

Crie um arquivo chamado flask_server.py documento:

from flask import Flask, request, jsonify
import grpc
import service_pb2
import service_pb2_grpc

app = Flask(__name__)

def get_grpc_client():
    channel = grpc.insecure_channel('localhost:50051')
    stub = service_pb2_grpc.DemoServiceStub(channel)
    return stub

@app.route('/hello', methods=['POST'])
def say_hello():
    data = request.json
    name = data.get('name')
    stub = get_grpc_client()
    response = stub.SayHello(service_pb2.HelloRequest(name=name))
    return jsonify({'message': response.message})

if __name__ == '__main__':
    app.run(port=5000, debug=True)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22

Execute o servidor

Abra duas janelas ou guias de terminal.

  1. Inicie o servidor gRPC no primeiro terminal:

    python grpc_server.py
    
    • 1
  2. Inicie o servidor Flask em um segundo terminal:

    python flask_server.py
    
    • 1

usar requests realizar testes

Crie um arquivo chamado test_flask_server.py arquivo e adicione o seguinte código:

import requests

def test_say_hello():
    url = 'http://localhost:5000/hello'
    data = {'name': 'World'}
    response = requests.post(url, json=data)
    
    if response.status_code == 200:
        print('Success!')
        print('Response JSON:', response.json())
    else:
        print('Failed!')
        print('Status Code:', response.status_code)
        print('Response Text:', response.text)

if __name__ == '__main__':
    test_say_hello()
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17

Execute testes

  1. certificar-se grpc_server.py eflask_server.py correndo.

  2. Execute em outro terminal test_flask_server.py

    python test_flask_server.py
    
    • 1

Você deverá ver uma saída como esta:

Success!
Response JSON: {'message': 'Hello, World!'}
  • 1
  • 2

Execute a captura de tela

Insira a descrição da imagem aqui

Este script de teste envia uma mensagem contendo name para"World" Solicitação POST do objeto JSON parahttp://localhost:5000/hello e imprima a resposta retornada pelo servidor. Se o servidor estiver funcionando corretamente, você verá uma mensagem de sucesso e os dados JSON retornados.