Aspire.Hosting.Azure.CosmosDB
8.2.0
Prefix Reserved
See the version list below for details.
dotnet add package Aspire.Hosting.Azure.CosmosDB --version 8.2.0
NuGet\Install-Package Aspire.Hosting.Azure.CosmosDB -Version 8.2.0
<PackageReference Include="Aspire.Hosting.Azure.CosmosDB" Version="8.2.0" />
paket add Aspire.Hosting.Azure.CosmosDB --version 8.2.0
#r "nuget: Aspire.Hosting.Azure.CosmosDB, 8.2.0"
// Install Aspire.Hosting.Azure.CosmosDB as a Cake Addin #addin nuget:?package=Aspire.Hosting.Azure.CosmosDB&version=8.2.0 // Install Aspire.Hosting.Azure.CosmosDB as a Cake Tool #tool nuget:?package=Aspire.Hosting.Azure.CosmosDB&version=8.2.0
Aspire.Hosting.Azure.Cosmos library
Provides extension methods and resource definitions for a .NET Aspire AppHost to configure Azure CosmosDB.
Getting started
Prerequisites
- Azure subscription - create one for free
Install the package
In your AppHost project, install the .NET Aspire Azure Cosmos DB Hosting library with NuGet:
dotnet add package Aspire.Hosting.Azure.Cosmos
Configure Azure Provisioning for local development
Adding Azure resources to the .NET Aspire application model will automatically enable development-time provisioning for Azure resources so that you don't need to configure them manually. Provisioning requires a number of settings to be available via .NET configuration. Set these values in user secrets in order to allow resources to be configured automatically.
{
"Azure": {
"SubscriptionId": "<your subscription id>",
"ResourceGroupPrefix": "<prefix for the resource group>",
"Location": "<azure location>"
}
}
NOTE: Developers must have Owner access to the target subscription so that role assignments can be configured for the provisioned resources.
Usage example
Then, in the Program.cs file of AppHost
, add a Cosmos DB connection and consume the connection using the following methods:
var cosmosdb = builder.AddAzureCosmosDB("cdb").AddDatabase("cosmosdb");
var myService = builder.AddProject<Projects.MyService>()
.WithReference(cosmosdb);
The WithReference
method passes that connection information into a connection string named cosmosdb
in the MyService
project. In the Program.cs file of MyService
, the connection can be consumed using the client library Aspire.Microsoft.Azure.Cosmos:
builder.AddAzureCosmosClient("cosmosdb");
Emulator usage
Aspire supports the usage of the Azure Cosmos DB emulator to use the emulator, add the following to your AppHost project:
// AppHost
var cosmosdb = builder.AddAzureCosmosDB("cosmos").RunAsEmulator();
When the AppHost starts up a local container running the Azure CosmosDB will also be started:
// Service code
builder.AddAzureCosmosClient("cosmos");
Additional documentation
- https://learn.microsoft.com/azure/cosmos-db/nosql/sdk-dotnet-v3
- https://github.com/dotnet/aspire/tree/main/src/Components/README.md
Feedback & contributing
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. |
-
net8.0
- Aspire.Hosting.Azure (>= 8.2.0)
- Azure.Core (>= 1.42.0)
- Azure.Identity (>= 1.12.0)
- Azure.Provisioning (>= 0.3.0)
- Azure.Provisioning.CosmosDB (>= 0.1.0)
- Azure.Provisioning.KeyVault (>= 0.2.0)
- Azure.Provisioning.Resources (>= 0.2.0)
- Azure.Security.KeyVault.Secrets (>= 4.6.0)
- Google.Protobuf (>= 3.27.3)
- Grpc.AspNetCore (>= 2.65.0)
- Grpc.Net.ClientFactory (>= 2.65.0)
- Grpc.Tools (>= 2.65.0)
- KubernetesClient (>= 14.0.9)
- Microsoft.Extensions.Configuration.Abstractions (>= 8.0.0)
- Microsoft.Extensions.Configuration.Binder (>= 8.0.2)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 8.0.1)
- Microsoft.Extensions.Hosting (>= 8.0.0)
- Microsoft.Extensions.Hosting.Abstractions (>= 8.0.0)
- Microsoft.Extensions.Http (>= 8.0.0)
- Microsoft.Extensions.Logging.Abstractions (>= 8.0.1)
- Microsoft.Extensions.Options (>= 8.0.2)
- Microsoft.Extensions.Primitives (>= 8.0.0)
- Polly.Core (>= 8.4.1)
- System.IO.Hashing (>= 8.0.0)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Aspire.Hosting.Azure.CosmosDB:
Package | Downloads |
---|---|
Hexalith.Infrastructure.AspireService.Hosting
Hexalith is a set of libraries to build a micro-service architecture. |
GitHub repositories (2)
Showing the top 2 popular GitHub repositories that depend on Aspire.Hosting.Azure.CosmosDB:
Repository | Stars |
---|---|
IEvangelist/azure-cosmos-dotnet-repository
Wraps the .NET SDK for Azure Cosmos DB abstracting away the complexity, exposing a simple CRUD-based repository pattern
|
|
J-Tech-Japan/Sekiban
Sekiban - an Opinionated Event Sourcing and CQRS Framework using C#. It can store data into Azure Cosmos DB, AWS Dynamo DB or Postgres
|
Version | Downloads | Last updated |
---|---|---|
9.0.0 | 9,600 | 11/12/2024 |
9.0.0-rc.1.24511.1 | 1,954 | 10/15/2024 |
8.2.2 | 3,874 | 10/24/2024 |
8.2.1 | 4,953 | 9/26/2024 |
8.2.0 | 15,003 | 8/29/2024 |
8.1.0 | 4,944 | 7/23/2024 |
8.0.2 | 2,551 | 6/28/2024 |
8.0.1 | 6,341 | 5/21/2024 |
8.0.0 | 306 | 5/21/2024 |
8.0.0-preview.7.24251.11 | 783 | 5/7/2024 |
8.0.0-preview.6.24214.1 | 2,857 | 4/23/2024 |
8.0.0-preview.5.24201.12 | 341 | 4/9/2024 |