Microsoft.Orleans.Transactions.AzureStorage
9.2.1
Prefix Reserved
dotnet add package Microsoft.Orleans.Transactions.AzureStorage --version 9.2.1
NuGet\Install-Package Microsoft.Orleans.Transactions.AzureStorage -Version 9.2.1
<PackageReference Include="Microsoft.Orleans.Transactions.AzureStorage" Version="9.2.1" />
<PackageVersion Include="Microsoft.Orleans.Transactions.AzureStorage" Version="9.2.1" />
<PackageReference Include="Microsoft.Orleans.Transactions.AzureStorage" />
paket add Microsoft.Orleans.Transactions.AzureStorage --version 9.2.1
#r "nuget: Microsoft.Orleans.Transactions.AzureStorage, 9.2.1"
#:package Microsoft.Orleans.Transactions.AzureStorage@9.2.1
#addin nuget:?package=Microsoft.Orleans.Transactions.AzureStorage&version=9.2.1
#tool nuget:?package=Microsoft.Orleans.Transactions.AzureStorage&version=9.2.1
Microsoft Orleans Transactions for Azure Storage
Introduction
Microsoft Orleans Transactions for Azure Storage provides the infrastructure to store Orleans transaction logs in Azure Storage. This package allows Orleans applications to use ACID transactions across multiple grain calls with Azure Storage as the backing transaction log store.
Getting Started
To use this package, install it via NuGet:
dotnet add package Microsoft.Orleans.Transactions.AzureStorage
Example - Configuring Azure Storage for Transactions
using Microsoft.Extensions.Hosting;
using Orleans.Configuration;
using Orleans.Hosting;
using Orleans.Transactions;
var builder = Host.CreateApplicationBuilder(args)
.UseOrleans(siloBuilder =>
{
siloBuilder
.UseLocalhostClustering()
// Enable transactions
.AddAzureTableTransactionalStateStorage(
name: "TransactionStore",
configureOptions: options =>
{
options.ConnectionString = "YOUR_AZURE_STORAGE_CONNECTION_STRING";
})
.UseTransactions();
});
// Run the host
await builder.RunAsync();
Example - Using Transactions in Grains
// A grain with transactional state
public class MyTransactionalGrain : Grain, IMyTransactionalGrain
{
private readonly ITransactionalState<MyState> _state;
// Inject the transactional state
public MyTransactionalGrain(
[TransactionalState("state", "TransactionStore")]
ITransactionalState<MyState> state)
{
_state = state;
}
// Method that performs a transaction
[Transaction(TransactionOption.Create)]
public async Task Transfer(string otherGrainKey, int amount)
{
// Read our state within the transaction
var myState = await _state.PerformRead(state => state);
// Ensure we have enough balance
if (myState.Balance < amount)
throw new InvalidOperationException("Insufficient funds");
// Update our state within the transaction
await _state.PerformUpdate(s => s.Balance -= amount);
// Call another grain within the same transaction
var otherGrain = GrainFactory.GetGrain<IMyTransactionalGrain>(otherGrainKey);
await otherGrain.Deposit(amount);
}
// Method that participates in a transaction
[Transaction(TransactionOption.Join)]
public Task Deposit(int amount)
{
// Update state within the joined transaction
return _state.PerformUpdate(s => s.Balance += amount);
}
// Read operation within a transaction
[Transaction(TransactionOption.CreateOrJoin)]
public Task<int> GetBalance()
{
return _state.PerformRead(s => s.Balance);
}
}
// State class
public class MyState
{
public int Balance { get; set; }
}
Documentation
For more comprehensive documentation, please refer to:
Feedback & Contributing
- If you have any issues or would like to provide feedback, please open an issue on GitHub
- Join our community on Discord
- Follow the @msftorleans Twitter account for Orleans announcements
- Contributions are welcome! Please review our contribution guidelines
- This project is licensed under the MIT license
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
-
net8.0
- Azure.Core (>= 1.46.2)
- Azure.Data.Tables (>= 12.9.1)
- Microsoft.AspNetCore.Connections.Abstractions (>= 8.0.11)
- Microsoft.CodeAnalysis.Analyzers (>= 3.11.0)
- Microsoft.CodeAnalysis.Common (>= 4.5.0)
- Microsoft.CodeAnalysis.Workspaces.Common (>= 4.5.0)
- Microsoft.Extensions.Configuration (>= 8.0.0)
- Microsoft.Extensions.Configuration.Abstractions (>= 8.0.0)
- Microsoft.Extensions.Configuration.Binder (>= 8.0.2)
- Microsoft.Extensions.Configuration.Json (>= 8.0.1)
- Microsoft.Extensions.DependencyInjection (>= 8.0.1)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 8.0.2)
- Microsoft.Extensions.DependencyModel (>= 8.0.2)
- Microsoft.Extensions.Hosting (>= 8.0.1)
- Microsoft.Extensions.Hosting.Abstractions (>= 8.0.1)
- Microsoft.Extensions.Logging (>= 8.0.1)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.3)
- Microsoft.Extensions.Logging.Console (>= 8.0.1)
- Microsoft.Extensions.Logging.Debug (>= 8.0.1)
- Microsoft.Extensions.ObjectPool (>= 8.0.11)
- Microsoft.Extensions.Options (>= 8.0.2)
- Microsoft.Extensions.Options.ConfigurationExtensions (>= 8.0.0)
- Microsoft.Orleans.Analyzers (>= 9.2.1)
- Microsoft.Orleans.CodeGenerator (>= 9.2.1)
- Microsoft.Orleans.Transactions (>= 9.2.1)
- Newtonsoft.Json (>= 13.0.3)
- System.Collections.Immutable (>= 8.0.0)
- System.IO.Hashing (>= 8.0.0)
- System.IO.Pipelines (>= 8.0.0)
- System.Memory.Data (>= 8.0.1)
- System.Text.Json (>= 8.0.5)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Microsoft.Orleans.Transactions.AzureStorage:
Package | Downloads |
---|---|
Microsoft.Orleans.Transactions.TestKit.Base
Testkit base library for transactions |
GitHub repositories (1)
Showing the top 1 popular GitHub repositories that depend on Microsoft.Orleans.Transactions.AzureStorage:
Repository | Stars |
---|---|
Dotnet-Boxed/Templates
.NET project templates with batteries included, providing the minimum amount of code required to get you going faster.
|
Version | Downloads | Last Updated |
---|---|---|
9.2.1 | 149 | 7/16/2025 |
9.2.0 | 174 | 7/14/2025 |
9.2.0-preview3 | 317 | 6/10/2025 |
9.2.0-preview2 | 160 | 6/4/2025 |
9.2.0-preview1 | 142 | 4/4/2025 |
9.1.2 | 3,298 | 2/13/2025 |
9.0.1 | 1,363 | 11/23/2024 |
9.0.0 | 364 | 11/14/2024 |
8.2.0 | 11,690 | 7/12/2024 |
8.2.0-preview1 | 203 | 5/22/2024 |
8.1.0 | 4,422 | 4/17/2024 |
8.1.0-preview3 | 237 | 3/11/2024 |
8.1.0-preview2 | 225 | 2/23/2024 |
8.1.0-preview1 | 285 | 2/13/2024 |
8.0.0 | 1,238 | 1/5/2024 |
8.0.0-rc2 | 476 | 12/20/2023 |
8.0.0-rc1 | 447 | 12/4/2023 |
7.2.7 | 221 | 10/15/2024 |
7.2.6 | 449 | 3/9/2024 |
7.2.5 | 2,374 | 2/22/2024 |
7.2.4 | 2,064 | 12/2/2023 |
7.2.3 | 669 | 11/3/2023 |
7.2.2 | 3,267 | 10/16/2023 |
7.2.1 | 8,460 | 7/11/2023 |
7.2.0 | 765 | 7/7/2023 |
7.1.2 | 22,972 | 4/19/2023 |
7.1.1 | 1,007 | 3/23/2023 |
7.1.0 | 1,506 | 2/1/2023 |
7.0.0 | 6,028 | 11/8/2022 |
7.0.0-rc2 | 680 | 10/19/2022 |
4.0.0-preview2 | 764 | 8/4/2022 |
4.0.0-preview1 | 1,078 | 2/10/2022 |
3.8.0 | 196 | 5/6/2025 |
3.8.0-preview5 | 256 | 5/12/2025 |
3.8.0-preview3 | 223 | 4/8/2025 |
3.8.0-preview2 | 181 | 4/4/2025 |
3.8.0-preview1 | 232 | 3/31/2025 |
3.7.2 | 277 | 5/10/2024 |
3.7.1 | 16,597 | 5/27/2023 |
3.7.0 | 1,464 | 3/23/2023 |
3.6.5 | 42,153 | 8/15/2022 |
3.6.4 | 1,862 | 8/10/2022 |
3.6.3 | 2,963 | 8/4/2022 |
3.6.2 | 10,885 | 4/15/2022 |
3.6.1 | 2,137 | 4/5/2022 |
3.6.0 | 25,984 | 1/20/2022 |
3.5.1 | 9,169 | 11/8/2021 |
3.5.0 | 14,913 | 9/3/2021 |
3.4.4 | 2,019 | 10/4/2021 |
3.4.3 | 14,508 | 6/3/2021 |
3.4.2 | 9,266 | 4/5/2021 |
3.4.1 | 10,384 | 2/3/2021 |
3.4.0 | 4,528 | 1/6/2021 |
3.4.0-rc1 | 1,327 | 12/9/2020 |
3.3.0 | 12,782 | 9/9/2020 |
3.3.0-rc2 | 1,529 | 9/2/2020 |
3.3.0-rc1 | 1,462 | 8/19/2020 |
3.2.2 | 6,281 | 7/22/2020 |
3.2.1 | 5,525 | 7/2/2020 |
3.2.0 | 3,288 | 6/4/2020 |
3.2.0-rc2 | 1,358 | 5/20/2020 |
3.2.0-rc1 | 1,628 | 5/7/2020 |
3.1.7 | 2,538 | 5/19/2020 |
3.1.6 | 2,581 | 4/16/2020 |
3.1.5 | 2,131 | 4/9/2020 |
3.1.4 | 4,617 | 3/26/2020 |
3.1.3 | 2,657 | 3/16/2020 |
3.1.2 | 2,620 | 3/5/2020 |
3.1.0 | 2,286 | 2/23/2020 |
3.1.0-rc3 | 1,496 | 2/13/2020 |
3.1.0-rc2 | 1,451 | 2/12/2020 |
3.1.0-rc1 | 1,483 | 2/10/2020 |
3.0.2 | 4,242 | 12/12/2019 |
3.0.1 | 3,489 | 11/27/2019 |
3.0.0 | 2,314 | 10/24/2019 |
3.0.0-rc2 | 1,578 | 10/16/2019 |
3.0.0-rc1 | 1,589 | 10/9/2019 |
3.0.0-beta1 | 1,454 | 8/16/2019 |
2.4.5 | 4,873 | 12/29/2019 |
2.4.4 | 2,135 | 11/27/2019 |
2.4.3 | 2,261 | 10/10/2019 |
2.4.2 | 4,224 | 8/31/2019 |
2.4.1 | 2,358 | 8/14/2019 |
2.4.0 | 3,875 | 8/8/2019 |
2.3.6 | 2,869 | 7/24/2019 |
2.3.5 | 2,757 | 6/14/2019 |
2.3.4 | 2,329 | 6/4/2019 |
2.3.3 | 2,273 | 6/2/2019 |
2.3.2 | 2,216 | 5/9/2019 |
2.3.1 | 2,415 | 4/26/2019 |
2.3.0 | 2,688 | 3/20/2019 |
2.3.0-rc2 | 1,489 | 3/13/2019 |
2.3.0-rc1 | 1,613 | 3/4/2019 |
2.2.4 | 1,723 | 2/25/2019 |
2.2.3 | 1,740 | 1/17/2019 |
2.2.2 | 2,365 | 1/10/2019 |
2.2.0 | 1,794 | 12/13/2018 |
2.2.0-rc1 | 1,487 | 12/4/2018 |
2.2.0-beta1 | 1,520 | 10/21/2018 |
2.1.2 | 1,871 | 10/11/2018 |
2.1.0 | 2,051 | 9/28/2018 |
2.1.0-rc2 | 1,722 | 9/21/2018 |
2.1.0-rc1 | 1,596 | 9/14/2018 |
2.1.0-beta1 | 1,631 | 8/27/2018 |
2.0.4 | 2,084 | 7/20/2018 |
2.0.0 | 2,300 | 3/28/2018 |
2.0.0-rc2 | 1,562 | 3/13/2018 |
2.0.0-rc1 | 1,691 | 2/26/2018 |
2.0.0-beta3 | 1,851 | 12/21/2017 |
2.0.0-beta2 | 1,835 | 12/11/2017 |