Docs Menu
Docs Home
/ /
/ / /

Transacciones

En esta guía, puedes aprender cómo usar el driver Java Reactive Streams para realizar transacciones. Las transacciones te permiten ejecutar una serie de operaciones que no se aplican hasta que se completen correctamente todos los cambios de datos. Si alguna operación en la transacción falla, el driver cancela la transacción y descarta todos los cambios en los datos antes de que sean visibles.

En MongoDB, las transacciones se ejecutan dentro de sesiones lógicas. Una sesión es un agrupamiento de operaciones de lectura o escritura relacionadas que se pretende ejecutar secuencialmente. Con las sesiones, puedes activar coherencia causal para un grupo de operaciones y ejecutar transacciones ACID. MongoDB garantiza que los datos involucrados en tus operaciones transaccionales se mantengan coherentes, incluso si las operaciones encuentran errores inesperados.

Cuando uses el driver de flujos reactivos Java puedes crear una nueva sesión a partir de un MongoClient instancia como un tipo ClientSession. Recomendamos reutilizar su cliente para múltiples sesiones y transacciones en lugar de crear una nueva instancia de cliente cada vez.

Advertencia

Utiliza un ClientSession solo con el MongoClient (o el MongoDatabase o MongoCollection asociados) que lo creaste. El uso de un ClientSession con un MongoClient diferente resulta en errores de operación.

Los ejemplos en esta guía utilizan las colecciones sample_restaurants.restaurants y sample_mflix.movies de los conjuntos de datos de muestra de Atlas. Para aprender a crear un clúster gratuito de MongoDB Atlas y cargar los conjuntos de datos de muestra, consulta el Comenzar.

Importante

Proyecto Reactor librería

Esta guía usa la librería Proyecto Reactor para consumir instancias Publisher devueltas por los métodos del driver Reactive Streams de Java. Para obtener más información sobre la biblioteca Project Reactor y cómo utilizarla, consulta Primeros pasos en la documentación de Reactor. Para obtener más información sobre cómo utilizamos los métodos de la librería Project Reactor en esta guía, consulta la guía Guardar datos en MongoDB.

Crea un(a) ClientSession utilizando el método startSession() en tu instancia de MongoClient. Luego, puedes modificar el estado de la sesión utilizando los métodos proporcionados por el ClientSession. La siguiente tabla detalla los métodos que puedes usar para gestionar tu transacción:

Método
Descripción

startTransaction()

Starts a new transaction, configured with the given options, on this session. Throws an exception if there is already a transaction in progress for the session. To learn more about this method, see the startTransaction() page in the MongoDB Server manual.

abortTransaction()

Ends the active transaction for this session. Throws an exception if there is no active transaction for the session or if the transaction is already committed or ended. To learn more about this method, see the abortTransaction() page in the MongoDB Server manual.

commitTransaction()

Commits the active transaction for this session. Throws an exception if there is no active transaction for the session or if the transaction was ended. To learn more about this method, see the commitTransaction() page in the MongoDB Server manual.

Tip

Tiempo de espera de la transacción

Puedes establecer un límite en la cantidad de tiempo que las operaciones pueden tardar en completarse en tus transacciones. Para obtener más información, consulta la sección Transacciones de la guía "Limitar el tiempo de ejecución del servidor".

El siguiente ejemplo demuestra cómo crear una sesión, realizar una transacción e insertar documentos en varias colecciones en una sola transacción. El código ejecuta los siguientes pasos:

  1. Crea una sesión desde el cliente usando el método startSession()

  2. Inicia una transacción utilizando el método startTransaction()

  3. Inserta documentos en las colecciones restaurants y movies

  4. Confirma la transacción utilizando el método commitTransaction()

MongoClient mongoClient = MongoClients.create(settings);
MongoDatabase restaurantsDatabase = mongoClient.getDatabase("sample_restaurants");
MongoCollection<Document> restaurants = restaurantsDatabase.getCollection("restaurants");
MongoDatabase moviesDatabase = mongoClient.getDatabase("sample_mflix");
MongoCollection<Document> movies = moviesDatabase.getCollection("movies");
Mono.from(mongoClient.startSession())
.flatMap(session -> {
// Begins the transaction
session.startTransaction();
// Inserts documents in the given order
return Mono.from(restaurants.insertOne(session, new Document("name", "Reactive Streams Pizza").append("cuisine", "Pizza")))
.then(Mono.from(movies.insertOne(session, new Document("title", "Java: Into the Streams").append("type", "Movie"))))
// Commits the transaction
.flatMap(result -> Mono.from(session.commitTransaction())
.thenReturn(result))
.onErrorResume(error -> Mono.from(session.abortTransaction()).then(Mono.error(error)))
.doFinally(signalType -> session.close());
})
// Closes the client after the transaction completes
.doFinally(signalType -> mongoClient.close())
// Prints the results of the transaction
.subscribe(
result -> System.out.println("Transaction succeeded"),
error -> System.err.println("Transaction failed: " + error)
);

Nota

Operaciones paralelas no admitidas

El driver de Java Reactive Streams no admite la ejecución de operaciones en paralelo dentro de una sola transacción.

Si estás utilizando MongoDB Server v8.0 o posterior, puedes realizar operaciones de escritura en múltiples espacios de nombres dentro de una sola transacción utilizando operaciones de escritura en bloque. Para obtener más información, consulta la sección Cliente Bulk Guardar de la guía Bulk Guardar Operaciones.

Para **aprender** más sobre los conceptos mencionados en esta **guía**, consulta las siguientes páginas en el manual del **servidor**:

Para aprender más sobre cualquiera de los tipos o métodos discutidos en esta guía, consulta la siguiente documentación de la API:

Volver

Guardado masivo

En esta página