Join us at MongoDB.local London on 7 May to unlock new possibilities for your data. Use WEB50 to save 50%.
Register now >
Docs Menu
Docs Home
/ /

Transacciones y Sesiones

En esta guía, puedes aprender cómo utilizar la librería de PHP de MongoDB para realizar transacciones. Las transacciones permiten realizar una serie de operaciones que modifican datos solo si se confirma toda la transacción. Si alguna operación en la transacción no tiene éxito, la librería detiene la transacción y descarta todos los cambios de datos antes de que se vuelvan visibles. Esta funcionalidad se denomina atomicidad.

En MongoDB, las transacciones se ejecutan dentro de sesiones lógicas. Una sesión es un grupo de operaciones de lectura o escritura relacionadas que deseas ejecutar de manera secuencial. Las sesiones permiten la coherencia causal para un grupo de operaciones y le permiten ejecutar operaciones en una transacción compatible con ACID, que es una transacción que cumple con una expectativa de atomicidad, consistencia, aislamiento y durabilidad. MongoDB garantiza que los datos involucrados en tus operaciones de transacción permanezcan coherentes, incluso si las operaciones encuentran errores inesperados.

Al utilizar la librería PHP de MongoDB, puedes crear una nueva sesión desde un(a) MongoDB\Client instancia. Luego, puede usar la instancia MongoDB\Driver\Session resultante para realizar transacciones.

Advertencia

Utilice un Session solo en operaciones que se ejecuten en el Client que lo creó. Usar un Session con un Client diferente da como resultado errores de operación.

MongoDB habilita la coherencia causal en ciertas sesiones de clientes. El modelo de coherencia causal garantiza que en un sistema distribuido, las operaciones dentro de una sesión se ejecuten en un orden causal. Los clientes observan resultados que son coherentes con las relaciones causales, o las dependencias entre las operaciones. Por ejemplo, si realizas una serie de operaciones donde una depende lógicamente del resultado de otra, las lecturas subsecuentes reflejarán esa relación de dependencia.

Para garantizar la coherencia causal, las sesiones de los clientes deben cumplir los siguientes requisitos:

  • Al iniciar una sesión, el controlador debe habilitar la opción de consistencia causal. Esta opción está habilitada por defecto.

  • Las operaciones deben ejecutarse en una sola sesión en un solo hilo. De lo contrario, las sesiones o hilos deben comunicarse entre sí el tiempo de operación y los valores de tiempo del clúster. Para ver un ejemplo de dos sesiones que comunican estos valores, consulta Ejemplos de consistencia causal en el manual del servidor MongoDB.

  • Debes utilizar una preocupación de lectura majority.

  • Debe usar un majority nivel de confirmación de escritura (write concern). Este es el valor predeterminado de nivel de confirmación de escritura (write concern).

La siguiente tabla describe las garantías que brindan las sesiones causalmente consistentes:

garantías
Descripción

Leer las escrituras

Las operaciones de lectura reflejan los resultados de las operaciones de escritura anteriores.

Lecturas monotónicas

Las operaciones de lectura no devuelven resultados que reflejen un estado de datos anterior al de una operación de lectura previa.

Escrituras monotónicas

Si una operación de escritura debe preceder a otras operaciones de escritura, el servidor ejecuta esta operación de escritura primero.

Por ejemplo, si llama a MongoDB\Collection::insertOne() para insertar un documento y luego llama a MongoDB\Collection::updateOne() para modificar el documento insertado, el servidor ejecuta primero la operación de inserción.

Las escrituras siguen a las lecturas

Si una operación de escritura debe seguir a otras operaciones de lectura, el servidor primero ejecuta las operaciones de lectura.

Por ejemplo, si llamas a MongoDB\Collection::findOne() para recuperar un documento y luego llamas a MongoDB\Collection::deleteOne() para borrar el documento recuperado, el servidor ejecutará primero la operación find.

Tip

Para aprender más sobre los conceptos mencionados en esta sección, consulta las siguientes entradas del manual del servidor MongoDB:

En esta sección, puedes aprender sobre las APIs de transacción proporcionadas por MongoDB PHP librería. Antes de iniciar una transacción, debes crear un Session usando el método MongoDB\Client::startSession() en tu instancia Client. Entonces, puedes utilizar cualquiera de las siguientes APIs para realizar una transacción:

La biblioteca PHP de MongoDB proporciona una práctica API de transacciones para gestionar el ciclo de vida de las transacciones. Implemente esta API usando la MongoDB\with_transaction() función para ejecutar una devolución de llamada personalizada dentro de una transacción. La with_transaction() función realiza las siguientes tareas:

  • Inicia la transacción

  • Gestiona errores finalizando la transacción o reintentándola, como cuando la operación retorna un TransientTransactionError

  • Confirma la transacción

La sección Ejemplo de Transacción de esta guía muestra cómo utilizar esta API para realizar una transacción.

Alternativamente, puedes tener más control sobre el ciclo de vida de tus transacciones utilizando los métodos proporcionados por la clase Session. La siguiente tabla describe estos métodos:

Método
Descripción

startTransaction()

Starts a new transaction on this session. The session must be passed into each operation within the transaction, or the operation will run outside of the transaction.

You can set transaction options by passing an options parameter.

commitTransaction()

Commits the active transaction for this session. This method returns an error if there is no active transaction for the session, the transaction was previously ended, or if there is a write conflict.

abortTransaction()

Ends the active transaction for this session. This method returns an error if there is no active transaction for the session or if the transaction was committed or ended.

Este ejemplo define una función de devolución de llamada que modifica los datos de las colecciones de la base de datos bank para una transacción bancaria. El código realiza las siguientes acciones:

  • Crea Collection instancias para acceder a las colecciones de destino.

  • Especifica el número de cuenta y el monto que se transferirá entre cuentas.

  • Define la función de retorno, que recibe la instancia Session como parámetro.

  • Actualiza los saldos del cliente para reflejar la transferencia de dinero.

  • Registra un recibo de la transacción con una marca de tiempo.

  • Imprime un mensaje si la transacción se comprometió correctamente.

$receipts = $client->bank->receipts;
$checking = $client->bank->checking_accounts;
$saving = $client->bank->saving_accounts;
$accountId = '5678';
$transferAmount = 1000.0;
$callback = function (MongoDB\Driver\Session $session) use (
$checking,
$saving,
$receipts,
$accountId,
$transferAmount,
): void {
$checking->updateOne(
['account_id' => $accountId],
['$inc' => ['balance' => -$transferAmount]],
['session' => $session],
);
$saving->updateOne(
['account_id' => $accountId],
['$inc' => ['balance' => $transferAmount]],
['session' => $session],
);
$summary = sprintf('SAVINGS +%1$u CHECKING -%1$u', $transferAmount);
$receipts->insertOne(
[
'account_id' => $accountId,
'summary' => $summary,
'timestamp' => new MongoDB\BSON\UTCDateTime(),
],
['session' => $session],
);
echo 'Successfully performed transaction!', PHP_EOL;
echo 'Summary: ', $summary, PHP_EOL;
};

A continuación, ejecuta el siguiente código para realizar la transacción. Este código completa las siguientes acciones:

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

  2. Llama a la función with_transaction() para gestionar la transacción, pasando como parámetros la sesión y la función de retorno.

$session = $client->startSession();
try {
MongoDB\with_transaction($session, $callback);
} catch (MongoDB\Driver\Exception\RuntimeException $e) {
echo 'Caught exception: ', $e->getMessage(), PHP_EOL;
}
Successfully performed transaction!
Summary: SAVINGS +1000 CHECKING -1000

Nota

Operaciones paralelas no admitidas

La librería PHP no admite la ejecución de operaciones en paralelo dentro de una única transacción.

Para obtener más información sobre los conceptos mencionados en esta guía, consulte las siguientes páginas del manual de MongoDB Server:

Para aprender más sobre ACID compliance, consulte el ¿Cuáles son las propiedades ACID en los sistemas de gestión de bases de datos? artículo en el sitio web de MongoDB.

Para obtener más información sobre las operaciones de inserción, consulta la Guía deinserción de documentos.

Para obtener más información sobre los métodos y tipos mencionados en esta guía, vea la siguiente documentación de la API:

Para obtener más información sobre la clase Session y los métodos, consulte la siguiente documentación de la API de extensión PHP:

Volver

Operaciones de escritura masiva

En esta página