Getting Started
Transports
Persistence
ServiceInsight
ServicePulse
ServiceControl
Monitoring
Previews
Samples

Transactional Session with CosmosDB Persistence

NuGet Package: NServiceBus.Persistence.CosmosDB.TransactionalSession (2-pre)
This page targets a pre-release version. Pre-releases are subject to change and samples are not guaranteed to be fully functional.

In order to use the TransactionalSession feature with CosmosDB Persistence, add a reference to the NServiceBus.Persistence.CosmosDB.TransactionalSession NuGet package.

Configuration

To enable the TransactionalSession feature:

var persistence = config.UsePersistence<CosmosPersistence>();
persistence.EnableTransactionalSession();

Opening a session

To open a CosmosDB transactional session, a partition key must be provided:

using var childScope = serviceProvider.CreateScope();
var session = childScope.ServiceProvider.GetService<ITransactionalSession>();
await session.Open(
        new CosmosOpenSessionOptions(
            new PartitionKey("MyPartitionKey")))
    .ConfigureAwait(false);

// use the session

await session.Commit()
    .ConfigureAwait(false);

Custom container

By default, the transactional session uses the configured default container. The CosmosOpenSessionOptions can be configured with container information to be used for this transaction:

using var childScope = serviceProvider.CreateScope();
var session = childScope.ServiceProvider.GetService<ITransactionalSession>();
await session.Open(
        new CosmosOpenSessionOptions(
            new PartitionKey("MyPartitionKey"),
            new ContainerInformation(
                "MyContainer",
                new PartitionKeyPath("/path/to/partition/key"))))
    .ConfigureAwait(false);

// use the session

await session.Commit()
    .ConfigureAwait(false);

Transaction usage

Message and database operations made via the the transactional session are committed together once the session is committed:

await session.Open(
        new CosmosOpenSessionOptions(
            new PartitionKey("MyPartitionKey")))
             .ConfigureAwait(false);

// add messages to the transaction:
await session.Send(new MyMessage())
    .ConfigureAwait(false);

// access the database:
var cosmosSession = session.SynchronizedStorageSession.CosmosPersistenceSession();

await session.Commit()
    .ConfigureAwait(false);

See the Cosmos DB persistence transactions documentation for further details about using the transaction.

In order to guarantee atomic consistency across message and database operations, the Outbox needs to be enabled. Otherwise Commit executes database modifications first and then messages are dispatched with best-effort.

Related Articles


Last modified