Compartir tecnología

[Python] Proyecto simple de Python Flask y gRPC

2024-07-12

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

Proyectos de muestra de Python Flask y gRPC

Este artículo presentará cómo crear una aplicación de muestra simple usando Flask y gRPC en Python y cómo usar requests biblioteca para realizar pruebas.

Configuración del entorno

Primero, asegúrese de tener Python instalado. Luego, cree un entorno virtual para administrar sus dependencias.

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

Instalar los paquetes necesarios:

pip install Flask grpcio grpcio-tools requests
  • 1

Definir el servicio gRPC

Crear .proto archivo para definir el servicio gRPC.Guardar nombre de archivoservice.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

Generar código Python a partir de archivos Proto

usar grpc_tools Generar código Python:

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

Esto generará dos archivos:service_pb2.py yservice_pb2_grpc.py

Implementar servidor gRPC

Crea un archivo llamado 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 el servidor Flask

Crea un archivo llamado 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

Ejecute el servidor

Abra dos ventanas o pestañas de terminal.

  1. Inicie el servidor gRPC en la primera terminal:

    python grpc_server.py
    
    • 1
  2. Inicie el servidor Flask en una segunda terminal:

    python flask_server.py
    
    • 1

usar requests realizar pruebas

Crea un archivo llamado test_flask_server.py archivo y agregue el siguiente 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

Ejecutar pruebas

  1. Cerciorarse grpc_server.py yflask_server.py correr.

  2. Ejecutar en otra terminal test_flask_server.py

    python test_flask_server.py
    
    • 1

Deberías ver un resultado como este:

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

Ejecutar captura de pantalla

Insertar descripción de la imagen aquí

Este script de prueba envía un mensaje que contiene name para"World" Solicitud POST del objeto JSON ahttp://localhost:5000/hello y luego imprima la respuesta devuelta por el servidor. Si el servidor funciona correctamente, verá un mensaje de éxito y se devolverán los datos JSON.