Nota
La funcionalidad Stable API requiere MongoDB Server 5.0 o posterior.
Solo debe usar la Stable API si todos los servidores de MongoDB a los que se conecta admiten esta funcionalidad.
Overview
En esta guía, puede aprender cómo especificar la Stable API al conectarse a una instancia de MongoDB o a un set de réplicas. Puedes usar la funcionalidad Stable API para forzar que el servidor ejecute operaciones con un comportamiento compatible con la versión de API especificada. Una versión de API define el comportamiento esperado de las operaciones que cubre y el formato de las respuestas del servidor. Si cambias a una versión diferente de la API, no se garantiza que las operaciones sean compatibles y no se garantiza que las respuestas del servidor sean similares.
Cuando utilices la funcionalidad Stable API con un driver oficial de MongoDB, podrás actualizar tu driver o servidor sin preocuparte por problemas de retrocompatibilidad de los comandos cubiertos por la Stable API.
Consulte la página de referencia de MongoDB sobre el Stable API para más información, incluido un listado de los comandos que cubre.
Las siguientes secciones describen cómo se puede habilitar la Stable API para el cliente de MongoDB y las opciones que se pueden especificar.
Habilita la Stable API en un cliente de MongoDB
Para habilitar la Stable API, debes especificar una versión de la API en la configuración de tu cliente de MongoDB. Una vez que instancias una MongoClient instancia con una versión de API especificada, todos los comandos que ejecutes con ese cliente utilizan esa versión de la API estable.
Tip
Para ejecutar comandos que utilizan más de una versión de la Stable API, cree una instancia de un cliente separado con esa versión.
Para ejecutar comandos que no estén cubiertos por la Stable API, asegúrate de que la opción "estricta" esté deshabilitada. Consulte la sección sobre Opciones de Stable API para obtener más información.
El siguiente ejemplo muestra cómo puedes crear una instancia de MongoClient que establezca la versión de la Stable API y se conecte a un servidor realizando las siguientes operaciones:
Construya una instancia
ServerApiusando la clase asistenteServerApi.Builder.Especifica una Stable API usando una constante de la clase
ServerApiVersion.Construir una instancia de
MongoClientSettingsusando la claseMongoClientSettings.Builder.Especifique un servidor al que conectarse usando una instancia de
ServerAddress.Instancia un
MongoClientusando el métodoMongoClients.create()y pasa tu instanciaMongoClientSettingscomo parámetro.
ServerApi serverApi = ServerApi.builder() .version(ServerApiVersion.V1) .build(); // Replace the uri string with your MongoDB deployment's connection string String uri = "<connection string uri>"; MongoClientSettings settings = MongoClientSettings.builder() .applyConnectionString(new ConnectionString(uri)) .serverApi(serverApi) .build(); MongoClient client = MongoClients.create(settings);
Advertencia
Si especificas una versión de API y te conectas a una implementación de MongoDB que no admite la Stable API, tu aplicación podría generar una excepción al ejecutar un comando en la implementación de MongoDB. Si usas un MongoClient que especifica la versión de la API para consultar a un servidor que no la admite, tu query puede fallar con un mensaje de excepción que incluye el siguiente texto:
'Unrecognized field 'apiVersion' on server...
Para obtener más información sobre los métodos y clases mencionados en esta sección, consulta la siguiente documentación de la API:
Opciones de Stable API
Puedes habilitar o deshabilitar el comportamiento opcional relacionado con la Stable API como se describe en la siguiente tabla.
Nombre de la opción | Descripción |
|---|---|
Estricto | opcional. Cuando se establece, si se llama a un comando que no forma parte de la versión de API declarada, el driver genera una excepción. Por defecto: false |
Errores de obsolescencia | opcional. Cuando se configura, si realizas una llamada a un comando que está obsoleto en la versión de API declarada, el controlador genera una excepción. Por defecto: false |
El siguiente ejemplo muestra cómo se pueden establecer las dos opciones en una instancia de ServerApi encadenando métodos en el ServerApi.Builder:
ServerApi serverApi = ServerApi.builder() .version(ServerApiVersion.V1) .strict(true) .deprecationErrors(true) .build();
Para obtener más información sobre las opciones en esta sección, consulte la siguiente documentación de la API: