Descubra qué hay de nuevo en:
Novedades en la 5.7
La versión del controlador 5.7 incluye los siguientes cambios, correcciones y funcionalidades:
Importante: La próxima versión menor dejará de ser compatible con la versión 4.2 de MongoDB Server y aumentará la versión mínima compatible a la 4.4. Este cambio se alinea con los cronogramas del ciclo de vida del software de MongoDB.
Recomendamos realizar cambios en tu aplicación para adaptarse a los cambios disruptivos. Para obtener más información sobre cómo actualizar su versión del servidor, consulte la sección Notas de la versión en el manual de MongoDB Server.
Añade soporte para Scala 3.
Agrega soporte de incrustación automática como parte de las API de búsqueda vectorial.
Agrega soporte de seguimiento de Micrometer/OpenTelemetry al controlador de reactive-streams e incluye mejoras generales en el soporte de Micrometer.
Agrega soporte de bucle asincrónico seguro para la pila con el patrón de trampolín para prevenir errores de Stack Overflow.
Mejora el manejo de los tiempos de espera en el lado del cliente para considerar mejor las variaciones en el tiempo de ida y vuelta (RTT), junto con diversas pequeñas mejoras relacionadas con los tiempos de espera.
Reuses
ConnectionSourcepara evitar una selección extra de servidor.Restaura la ruta optimizada del códec para la codificación de
RawBsonDocument, corrigiendo una regresión en el rendimiento.Libera la conexión entre las respuestas vacías
getMoreenAsyncCommandCursor, evitando el agotamiento del pool de conexiones cuando los change streams inactivos alcanzanmaxPoolSize.El cliente de cifrado ahora utiliza una mayoría de
writeConcern.Maneja errores inesperados de fin de flujo desde KMS.
Corrige el
JsonBsonEncoderanálisis de los númerosJsonPrimitive, donde los números formateados científicamente se analizaban como Ints o Longs simples.Simplifica los nombres de los hilos de
ServerMonitory elimina el carácter=, que algunos sistemas de supervisión no pueden procesar.Corregir la decodificación BSON opcional de Kotlin.
Actualiza
libmongocrypta 1.17.3.Utiliza
ZstdInputStreamNoFinalizerpara la descompresión Zstandard.Actualiza Netty a la última versión.
Actualizar Snappy para las últimas correcciones de seguridad.
Actualiza JUnit 5 a la última versión.
Alinea el nivel de registro a advertencia al remover un servidor del clúster.
Novedades en la versión 5.6
La versión del controlador 5.6 incluye los siguientes cambios, correcciones y funcionalidades:
Agrega soporte experimental para las consultas de prefijo, sufijo y subcadena de Queryable Encryption. Para obtener más información sobre Aseguramiento de la Calidad, consulta encriptación en uso.
Nota
Funcionalidad Experimental
Las consultas de prefijos, sufijos y subcadenas con cifrado consultable (Queryable Encryption) son inestables y su seguridad no está garantizada hasta que estén generalmente disponibles (GA). Utilícelos solo en cargas de trabajo experimentales.
Añade un campo
nsTypea los objetosChangeStreamDocument. Este campo contiene el tipo de namespace (COLLECTION,TIMESERIESoVIEW) del evento de cambio.Agrega soporte experimental para la expiración de la operación en el lado del cliente (CSOT) para la autenticación OIDC.
Nota
Funcionalidad Experimental
La funcionalidad CSOT es experimental y podría cambiar en futuras versiones de driver.
Cuando
timeoutMSestá configurado para CSOT, el controlador ignora el valor de la configuración de conexión demaxWaitTime.Agrega un método
appendMetadata()a la claseMongoClient. Puedes utilizar este método para adjuntar metadatos a los metadatos de un cliente existente. El tamaño máximo de metadatos es 512 MB.Agrega un constructor público a la clase
RewrapManyDataKeyOptions.Fusiona las interfaces
AsyncReadOperationyAsyncWriteOperationen las interfacesReadOperationyWriteOperation. Puedes crear operaciones de lectura y guardar utilizando métodos constructores en la claseOperations.Obsoleta la constante
MongoNamespace.COMMAND_COLLECTION_NAME.Corrige un error que impedía la reautenticación OIDC dentro de una sesión.
Al serializar un POJO anotado con
@BsonDiscriminator, si lareadNamede la propiedad coincide con la clave de discriminador, el driver serializa el campo solo una vez.Después de llamar al método
next()otryNext()en una instancia deCommandCursorResult, el driver limpia la propiedadCommandCursorResult.resultspara liberar memoria.La clase
PojoBuilderHelpercrea modelos de propiedades que incluyen las propiedades de las clases abstractas e interfaces.El controlador publica y registra los siguientes eventos cuando la topología del clúster cambia:
ClusterOpeningEventPublicado cuando se abre la topologíaClusterDescriptionChangedEventSe publica cuando cambia la descripción de la topologíaClusterClosedEventPublicado cuando la topología se cierra
El driver lanza un/a
MongoStalePrimaryExceptioncuando el miembro primario del set de réplicas se queda obsoleto por una de las siguientes razones:Se elige o se descubre un nuevo miembro principal.
El valor del campo
electionIdosetVersionen el primario no coincide con los valores de estos campos en los otros miembros del set de réplicas.
Para obtener más información sobre sets de réplicas, consulta Replicación en el manual del servidor de MongoDB.
Novedades en 5.5.1
El 5.5.1 La versión de parchado del driver incluye los siguientes cambios:
Corrige un problema donde la reautenticación OIDC fallaba cuando era activada por una operación ejecutada en una sesión, incluyendo operaciones ejecutadas en una transacción.
Novedades en la versión 5.5
Importante
Eliminación del soporte para el servidor MongoDB 4.0
Driver de Kotlin v5.5 remueve el soporte para el servidor MongoDB 4.0. Para obtener más información sobre las versiones compatibles del servidor, consulte Compatibilidad.
La versión del controlador 5.5 incluye los siguientes cambios, correcciones y funcionalidades:
Agrega soporte para la opción
connectTimeoutMScuando se usa la capa de transporte TLS por defecto.
Introduce mejoras de rendimiento que se reflejan en los benchmarks de rendimiento del controlador. Para ver los resultados de las pruebas de referencia de rendimiento, vea la siguiente sección Mejoras de rendimiento.
Mejoras en el rendimiento
Las tablas en esta sección muestran los resultados de las pruebas de rendimiento para el controlador Java síncrono. Las pruebas se realizaron en una implementación de MongoDB Server 8.0 con la siguiente configuración:
En funcionamiento en
localhostcon una latencia de red insignificante. En entornos con mayor latencia, es posible que observes mejoras de rendimiento menos significativas.Autenticación desactivada.
TLS deshabilitado.
Esperamos aumentos de rendimiento similares para todos los controladores Java de MongoDB porque comparten la API mejorada de driver-core.
Configuración estándar de transporte
La siguiente tabla muestra los resultados de las pruebas de rendimiento para la versión5.5 del controlador configurado con ajustes estándar de transporte. Cada fila incluye la funcionalidad evaluada, el porcentaje de mejora en el rendimiento y el z-score.
funcionalidad | Porcentaje de mejora | Puntaje Z |
|---|---|---|
Decodificación profunda de BSON | 19.44% | 5.4 |
Codificación BSON profunda | 102% | 22.8 |
Encontrar varios y vaciar el cursor | 25.08% | 13.72 |
Encontrar uno por ID | 2.7% | 3.16 |
Decodificación BSON plana | 31.2% | 9.38 |
Codificación BSON plana | 199.5% | 12.34 |
Decodificación completa de BSON | 16.5% | 7.23 |
Codificación BSON completa | 147.3% | 10.39 |
Importación de varios archivos JSON-LD | 21.8% | 8.21 |
Inserción masiva de clientes con documentos grandes | 91.3% | 24.44 |
Inserción en masa de colecciones con documentos grandes | 96.5% | 8.79 |
Inserción masiva con documentos grandes | 93.3% | 8.11 |
Inserción masiva con documentos pequeños | 39.3% | 5.72 |
Inserte uno con documentos grandes | 82.4% | 7.28 |
Inserción masiva de clientes con documentos pequeños | 49.5% | 17.99 |
Inserción masiva en colecciones con documentos pequeños | 47.8% | 6.44 |
Configuración de transporte de Netty
La siguiente tabla muestra los resultados de las pruebas de rendimiento para la v5.5 del controlador configurado con la configuración de transporte Netty. Cada fila incluye la funcionalidad probada, el porcentaje de mejora en el rendimiento, y el z-score.
funcionalidad | Porcentaje de mejora | Puntaje Z |
|---|---|---|
Encontrar varios y vaciar el cursor | 40.3% | 14.81 |
Encontrar uno por ID | 4.4% | 4.12 |
Importación de varios archivos JSON-LD | 16.9% | 3.77 |
Inserción masiva de clientes con documentos grandes | 54.8% | 14.49 |
Inserción en masa de colecciones con documentos grandes | 104.9% | 38.72 |
Inserción masiva con documentos grandes | 74.6% | 65.55 |
Inserte uno con documentos grandes | 66.6% | 58.65 |
Inserción masiva de clientes con documentos pequeños | 36.1% | 15.41 |
Inserción masiva en colecciones con documentos pequeños | 39.3% | 37.38 |
Inserción masiva con documentos pequeños | 35.1% | 41.51 |
Tip
Para obtener más información sobre cómo realizamos pruebas de referencia del desempeño de los conductores, consulte la Evaluación comparativa del desempeño especificación.
Novedades en 5.4
La versión del controlador 5.4 incluye los siguientes cambios, correcciones y funcionalidades:
Agrega soporte
BsonConfigurationpara la conversión a snake case debson-kotlinxdurante la serialización. Para aprender más, consulta la sección Implementar la estrategia de nomenclatura en snake case en la página de serialización.
Admite operaciones
$lookuppara CSFLE y QE. Para aprender más, consulte las siguientes referencias en el manual del servidor:Introduce un Bill of Materials (BOM) para gestionar las versiones de los artefactos JVM de MongoDB que podrías utilizar en tu aplicación. Para ver las instrucciones sobre cómo agregar la lista de materiales (BOM) a la aplicación, consulte el paso Agregar la lista de materiales del controlador en la guía de inicio rápido.
Actualiza las dependencias del SDK de AWS a 2.30.31 y 1.12.782 para probar el mecanismo de autenticación
MONGODB-AWS.Agrega una opción de ordenación a las clases
ClientUpdateOneOptionsyClientReplaceOneOptions. Este cambio le permite establecer un orden de clasificación para las operaciones de actualización y reemplazo en las escrituras masivas de clientes. Para obtener más información, consulta las secciones Actualizar operación y Reemplazar operación de la guía de Bulk Operations.Agrega soporte para Kubernetes en la autenticación OIDC. Para obtener más información, consulta la sección MONGODB-OIDC: Kubernetes de la guía de Mecanismos de autenticación de empresa.
Agrega soporte de primera clase para los siguientes operadores del query de MongoDB Search:
phraseregexqueryStringequalsmoreLikeThisinwildcard
Para aprender más, consulta la sección Métodos de operadores de búsqueda de la guía de desarrolladores de agregaciones.
Actualiza los cursores para refrescar la configuración
timeoutMScuando llamas aclose()sin afectar el tiempo de espera de la operación.Le permite utilizar un índice al llamar al método
distinct()especificando una opciónhint.
Para ver una lista completa de los cambios de esta versión, consulta las notas de versión v5.4 en GitHub.
Novedades en la versión 5.3
La versión del controlador 5.3 incluye las siguientes nuevas funcionalidades, mejoras y correcciones:
Importante: La próxima versión menor dejará de ser compatible con la versión del servidor MongoDB 4.0 y aumentará la versión mínima compatible a la 4.2. Recomendamos realizar cambios en tu aplicación para adaptarla a los cambios disruptivos. Consulta la sección Notas de la versión en el manual del servidor para obtener más información sobre la actualización.
Agrega la clase
BinaryVectorpara implementar el Subtipo Binario BSON 9 para el almacenamiento y recuperación de vectores. Esta clase proporciona un almacenamiento más eficaz de los valores en comparación con una lista de instancias deDouble. Puedes crear los siguientes tipos de vectores en función del tipo de elementos que contiene tu vector:Int8BinaryVectorVectores de números enteros con signo de 8bitsFloat32BinaryVector: Vector de n\u00fameros de punto flotantePackedBitBinaryVector: Vector binario cuantizado (En beta y sujeto a cambios antes de estar disponible para el público en general)
Para aprender más sobre esta funcionalidad, consulte Vector Quantization en la documentación de Atlas. Para aprender a utilizar este tipo al usar la funcionalidad de Búsqueda de Vectores de MongoDB, consulta la guía de MongoDB Vector Search.
Elimina la equidad explícita de la implementación del pool de conexiones. Este cambio podría contribuir a un mejor rendimiento cuando utilices una instancia
MongoClienten muchos hilos de aplicación. Sin embargo, este cambio podría causar un aumento de la latencia de cola.Agrega una opción de ordenamiento a los métodos
updateOne()yreplaceOne(). Este cambio también le permite establecer un tipo de ordenación como opción al crear instancias deReplaceOneModelyUpdateOneModel. Para más información, consulta las guías Actualizar Documentos y Operaciones en Lote.
Soporte para usar los métodos de clase de desarrolladores directamente con las propiedades de clase de datos. Para obtener más información, consulta la Guía para usar Builders con Clases de Datos. Esta funcionalidad es compatible con el paquete de extensiones del controlador de Kotlin publicado con esta versión.
Implementa una API de escritura masiva cliente que permite realizar operaciones de escritura en varias bases de datos y colecciones en la misma llamada. Para obtener más información sobre esta funcionalidad, consulta la sección Escritura masiva del Cliente de la guía Operaciones masivas.
Novedades en 5.2
Importante
Eliminación del soporte para el servidor MongoDB 3.6
Driver de Kotlin v5.2 remueve el soporte para el servidor MongoDB 3.6. Para obtener más información sobre las versiones compatibles del servidor, consulte Compatibilidad.
La versión del controlador 5.2 incluye las siguientes nuevas funcionalidades, mejoras y correcciones:
Permite configurar un tiempo de espera para operaciones del lado del cliente (CSOT). Esta funcionalidad permite establecer un solo tiempo de espera en tu instancia de
MongoClientque se aplica a todas las operaciones realizadas con ese cliente. Para obtener más información, consulta la guía Limitar el tiempo de ejecución del servidor.Si, y sólo si, la funcionalidad CSOT está habilitada, las siguientes opciones de tiempo de espera serán ignoradas por el driver:
waitQueueTimeoutMSsocketTimeoutMSwTimeoutMSmaxTimeMSmaxCommitTimeMS
Importante
Funcionalidad Experimental
CSOT es una funcionalidad experimental y aún no está lista para producción. Esta funcionalidad es opcional en la versión actual y las opciones de tiempo de espera existentes siguen siendo funcionales.
Agrega la clase
SearchIndexType, que puedes pasar al construir una instancia deSearchIndexModel. Este cambio te permite especificar el tipo de índice al crear un índice de Atlas Search o búsqueda vectorial. Para saber más, consulta MongoDB Search y MongoDB Vector Search Indexes en la guía de Índices.Delegar la implementación de los algoritmos que implementan los mecanismos de autenticación
SCRAM-SHA-1ySCRAM-SHA-256en el proveedor JCA configurado. Este cambio significa que tu aplicación puede usar un proveedor JCA configurado conforme a FIPS para ofrecer un mayor nivel de seguridad.Revisa la versionado de la dependencia mongodb-crypt para que coincida con el versionado de los drivers JVM. Las futuras versiones de
mongodb-cryptse publicarán junto con el controlador y compartirán el mismo número de versión. Debes actualizar tu dependenciamongodb-crypta la versión v5.2.0 cuando actualices tu Driver para esta versión. Para saber más, puedes consultar la Guía de cifrado en uso.Mejoras de rendimiento debido a la implementación de criptografía nativa en todas las plataformas compatibles. La siguiente lista describe las acciones necesarias para implementar esta mejora según tu sistema operativo:
Windows: actualiza tu versión de
mongodb-crypta la v5.2.0.Mac: actualice su versión de
mongodb-crypta v5.2.0.Linux: Instala
libmongocrypt.sodirectamente en el sistema de archivos, en vez de usar el archivo que está incluido dentro del archivo JARmongodb-crypt. Puedes encontrar instrucciones de Linux para instalarlibmongocrypten el manual del servidor. Si utilizas un gestor de paquetes para instalarlibmongocrypt, Java Native Access (JNA) lo encontrará ahí sin necesidad de más configuración. Como alternativa, puedes especificar la ruta de búsqueda configurando la variable de entornoLD_LIBRARY_PATHa la ruta de archivo del paquetelibmongocrypt.Recomendamos la instalación directa porque la librería compartida incluida no se enlaza con OpenSSL debido al potencial de incompatibilidades binarias con OpenSSL.
La carga de la librería compartida es manejada por JNA. Se puede consultar las reglas para el orden de búsqueda de carga de librerías en la documentación de la clase NativeLibrary.
Corrige un problema que causaba que los métodos
InsertOneResult.getInsertedId()yInsertManyResult.getInsertedIds()devolvieran identificadores de documentos incorrectos en algunas situaciones. Este cambio se aplica retroactivamente al driver de Kotlin v5.1.4 y v4.11.4.Cuando una operación de clúster segmentado no tiene éxito, el driver evita seleccionar el mismo servidor
mongospara reintentar la operación si hay otros servidoresmongosdisponibles.Agrega los metadatos de alcanzabilidad necesarios cuando tu aplicación utiliza GraalVM Native Image. Estos metadatos sustituyen la necesidad de recopilar metadatos de alcance cuando se utilizan las librerías del driver. Para aprender más, consulte Metadatos de alcanzabilidad en la documentación de GraalVM.
Este cambio no agrega las entradas de recursos
libjnidispatchylibmongocrypt, porque agregar entradas para todas las plataformas soportadas (destinos) afecta significativamente el tamaño de los ejecutables nativos construidos usando GraalVM Native Image. Consulta este archivo de muestra resource-config.json en el repositorio de GitHub del controlador para ver cómo especificar estas entradas explícitamente si tu aplicación depende de la libreríaorg.mongodb:mongodb-crypt.Permite una búsqueda vectorial precisa al extender la API de
VectorSearchOptionspara introducir los siguientes subtipos de opciones específicos:ExactVectorSearchOptions: Utiliza este tipo de opciones para habilitar la coincidencia precisa, asegurando que los resultados sean los vectores más cercanos a un vector de query determinado.ApproximateVectorSearchOptionsUtiliza este tipo de opción para habilitar búsquedas que podrían no devolver los vectores más cercanos exactos. Puedes enviar un parámetronumCandidatesal instanciar este tipo para especificar la cantidad de vecinos más cercanos a considerar.
Para obtener más información sobre el uso de la funcionalidad de MongoDB Vector Search, consulta MongoDB Vector Search en la guía "Aggregates Builders".
Agrega soporte para los serializadores de la librería
kotlinx-datetimeque permiten asignar los tipos de fecha y hora de Kotlin a BSON como los tipos esperados en lugar de cadenas. Para obtener más información, consulte la sección Serializar fechas y horas de la guía de serialización de Kotlin.Admite la serialización de los valores JsonElement. Para trabajar con el tipo
JsonElement, debes agregar la libreríakotlinx-serialization-jsoncomo una dependencia en tu aplicación.
Novedades en 5.1.3
El 5.1.3 La versión de parchado del driver incluye los siguientes cambios:
Corrige un problema que podía causar errores de aserción al usar tipos de
Cursor.
Novedades en 5.1.2
El 5.1.2 La versión de parchado del driver incluye los siguientes cambios:
Compatibilidad para codificar clases de datos de Kotlin con tipos de parámetros genéricos anulables. Por ejemplo, puedes codificar la clase
Containeren el siguiente código:data class Box<T>( val boxed: T ) data class Container( val box: Box<String?> )
Novedades en 5.1.1
El 5.1.1 La versión de parchado del driver incluye los siguientes cambios:
Cuando utilices el mecanismo de autenticación
MONGODB-OIDC, no debes incluir caracteres de coma en el valor de la cadena de conexiónauthMechanismProperties. Para aprender más sobre este comportamiento, consulta la sección MONGODB-OIDC de la guía de autenticación de empresa.
Novedades en 5.1
Advertencia
Descontinuaciones en este lanzamiento
Para evitar cambios disruptivos en futuras versiones principales del driver, reemplaza cualquier código de aplicación que dependa de elementos de programación obsoletos.
Esta sección incluye la siguiente información:
Obsolescencias en la 5.1
El soporte para MongoDB server v3.6 está obsoleto y se eliminará en la siguiente versión del driver. Para aprender a actualizar tu implementación del servidor de MongoDB, consulta las Notas de la versión en el manual del servidor de MongoDB.
Mejoras en 5.1
Pruebas internas de la tecnología de imagen nativa GraalVM. Estas pruebas implican compilar aplicaciones nativas utilizando la herramienta GraalVM native-image.
Soporte mejorado para el mecanismo de autenticación
MONGODB-OIDC. Para obtener más información sobre OIDC, consulta la sección OIDC (Federación de identidad de cargas de trabajo) en la guía de mecanismos de autenticación empresarial.Corrige un problema en el que las operaciones utilizaban el códec incorrecto al usar una instancia polimórfica de
MongoCollection. Esto garantiza que la información del discriminador no se pierda al usarbson-kotlinx.Corrige un problema en el cual el discriminador de clases era el primer campo al decodificar, lo que resultaba en errores de tipo de campo al usar una instancia polimórfica de
MongoCollection.
Nuevas funcionalidades en 5.1
Compatibilidad con la serialización polimórfica. Para obtener más información, consulte la sección de Serialización polimórfica de la guía de Serialización de Kotlin.
Presenta la opción de URI de conexión
serverMonitoringMode. Para obtener más información, consulte la guía Opciones de conexión.
Qué hay de nuevo en 5.0
Entre las nuevas funcionalidades de la versión 5.0 de la versión de driver se incluyen:
El constructor
KotlinSerializerCodecProviderahora acepta objetosserializersModuleybsonConfiguration:KotlinSerializerCodec.create(clazz.kotlin, serializersModule=serializersModule, bsonConfiguration=bsonConfiguration) Esto facilita la personalización de tu configuración.
Soluciona un error de reflexión de Kotlin que ocasionaba el borrado del tipo de contenedor.
Novedades en 4.11
Esta sección incluye la siguiente información:
Obsolescencias en 4.11
Advertencia
Descontinuaciones en este lanzamiento
Para evitar cambios disruptivos en futuras versiones importantes del controlador, sustituya cualquier código de aplicación que dependa de métodos y tipos obsoletos.
La versión 4.11 del driver descontinúa los siguientes elementos:
Los siguientes métodos relacionados con la dirección de red están obsoletos y se eliminarán en la v5.0:
Los métodos ServerAddress
getSocketAddress()ygetSocketAddresses().En lugar de
getSocketAddress(), utiliza el método de instanciagetByName()dejava.net.InetAddress.En lugar de
getSocketAddresses(), utiliza el método de instanciagetAllByName()dejava.net.InetAddress.El método UnixServerAddress
getUnixSocketAddress().En lugar de
getUnixSocketAddress(), construya una instancia dejnr.unixsocket.UnixSocketAddress. Pasar la ruta completa del archivo del socket UNIX al constructor. Por defecto, MongoDB crea un archivo de socket UNIX situado en"/tmp/mongodb-27017.sock". Para obtener más información sobre elUnixSocketAddress, consulta la documentación de la API UnixSocketAddress.
Los siguientes métodos y tipos relacionados con la interfaz StreamFactory están obsoletos y programados para ser eliminados en la versión v5.0:
streamFactoryFactory()método deMongoClientSettings.BuildergetStreamFactoryFactory()método deMongoClientSettingsNettyStreamFactoryFactoryclaseNettyStreamFactoryclaseAsynchronousSocketChannelStreamFactoryclaseAsynchronousSocketChannelStreamFactoryFactoryclaseBufferProviderclaseSocketStreamFactoryclaseStreamclaseStreamFactoryclaseStreamFactoryFactoryclaseTlsChannelStreamFactoryFactoryclase
Si configuras Netty utilizando
MongoClientSettings.Builder.streamFactoryFactory(), tu código podría parecerse al siguiente:import com.mongodb.connection.netty.NettyStreamFactoryFactory; // ... MongoClientSettings settings = MongoClientSettings.builder() .streamFactoryFactory(NettyStreamFactoryFactory.builder().build()) .build(); Reemplace este código con el TransportSettings.nettyBuilder() como se muestra en el siguiente ejemplo:
import com.mongodb.connection.TransportSettings; // ... MongoClientSettings settings = MongoClientSettings.builder() .transportSettings(TransportSettings.nettyBuilder().build()) .build();
Nuevas funcionalidades en 4.11
Las nuevas funciones de la versión 4.11 de driver incluyen:
Soporte para conectarse a MongoDB utilizando un proxy SOCKS5.
Se agregó el método
getSplitEvent()a la claseChangeStreamDocumentpara identificar fragmentos de un evento de flujo de cambios que excede los 16MB. Debe usar la etapa de agregación$changeStreamSplitLargeEventen su flujo de cambios para gestionar eventos que superen los 16 MB.Se ha agregado un generador de etapas de agregación para
$vectorSearch.Se agregaron asistentes para la gestión de índices de MongoDB Search.
Versiones actualizadas de las dependencias de las librerías de compresión Snappy y Zstd. Para obtener más información sobre las versiones actuales de las dependencias, consulta Compresión de red.
Se añadieron
getElapsedTime()métodos a las siguientes clases para supervisar la duración de los eventos del pool de conexiones:Soporte para hilos virtuales de Java 21 y concurrencia estructurada. Los componentes internos del controlador se actualizaron para evitar el fijado innecesario de hilos virtuales y preservar el estado interrumpido de un hilo, ya que esto último es importante para la concurrencia estructurada, donde se utiliza para la cancelación.
Para obtener más información sobre los hilos virtuales, consulta la propuesta de mejora de JDK sobre hilos virtuales. Para obtener más información sobre concurrencia estructurada, consulta la propuesta de mejora de JDK Concurrencia Estructurada .
Documentación API actualizada para los siguientes tipos:
Novedades en 4.10
Importante
A partir de la versión 4.10.1 del controlador de Kotlin, debe agregar la librería bson-kotlinx como una dependencia explícita para usar la librería kotlinx-serialization.
Soporte para el uso de Kotlin del lado del servidor, tanto para corrutinas como para aplicaciones sincrónicas.
Soporte de códec para clases de datos de Kotlin.
Soporte para la librería
kotlinx.serialization