Interfaces disponibles
Cuando interactúas con Spanner, puedes usar una de varias interfaces programáticas. Estas son las interfaces disponibles, en el orden en que recomendamos usarlas:
- Bibliotecas cliente: Las bibliotecas cliente de Spanner están disponibles en varios lenguajes y se compilan en gRPC. Estas bibliotecas cliente proporcionan una capa de abstracción sobre gRPC y manejan los detalles de administración de sesiones, ejecución de transacciones, reintentos y mucho más.
- Controladores de ORM y de framework: Google admite controladores de Spanner de código abierto para varias bibliotecas populares de asignación relacional de objetos (ORM) y frameworks, como JDBC. Estos controladores permiten el uso de bases de datos de Spanner a través de las APIs definidas por esos frameworks.
- API de RPC: Si no hay una biblioteca cliente o un controlador ORM disponibles para el lenguaje de programación que elegiste, usa la API de RPC, que se basa en gRPC. gRPC ofrece varios beneficios de rendimiento en comparación con el uso de la API de REST, incluida la representación de objetos en formato de búfer de protocolo (que son más rápidos de producir y consumir en comparación con JSON) y las conexiones persistentes (que generan una menor sobrecarga por solicitud). Obtén más información sobre estos y otros beneficios en Conceptos de gRPC.
- API de REST: Si no puedes usar las bibliotecas cliente de Spanner o la API de RPC, usa la API de REST. Ten en cuenta que algunas funciones que están disponibles en la API de RPC no son compatibles con la API de REST, como se indica a continuación.
API de RPC frente a API de REST
En esta tabla, se comparan las funciones de Spanner disponibles a través de sus interfaces de API de RPC y de REST.
| Función | ¿Está disponible en la API de RPC? | ¿Está disponible en la API de REST? |
|---|---|---|
| Cancelar una solicitud | Sí | No |
| Establecer una fecha límite o tiempo de espera para una solicitud | Sí | No |
| Enviar una solicitud de transmisión | Sí. consulta ExecuteStreamingSQL y StreamingRead. |
Parcial. La transmisión HTTP es compatible, pero el control de flujo a nivel de aplicación no lo es. |
Compatibilidad con funciones de bibliotecas cliente
En la siguiente tabla, se enumeran las bibliotecas cliente y se destacan las principales funciones de Spanner que admite cada una.