Skip to content
Docs Try Aspire
Docs Try

Persistent Volume

Aspire sample
C# AppHost

Clone, run, and explore this sample

This sample demonstrates how to configure a SQL Server container to use a persistent volume in Aspire, so that the data is persisted across app launches. This method can be used to persist data across instances of other container types configured in Aspire apps too, e.g. PostgreSQL, Redis, etc.

AzureAzure StorageBlazorC#DashboardDatabasesDockerEF CoreMigrationsPostgreSQLRedisSQL ServerVolumes
AppHost

The entry point that composes every resource and dependency in this sample's distributed application.

View on GitHub
AppHost.cs
var builder = DistributedApplication.CreateBuilder(args);
var sqlserver = builder.AddSqlServer("sqlserver")
.WithDataVolume()
.WithLifetime(ContainerLifetime.Persistent);
var sqlDatabase = sqlserver.AddDatabase("sqldb");
var blobs = builder.AddAzureStorage("Storage")
// Use the Azurite storage emulator for local development
.RunAsEmulator(emulator => emulator.WithDataVolume())
.AddBlobs("BlobConnection");
builder.AddProject<Projects.VolumeMount_BlazorWeb>("blazorweb")
.WithReference(sqlDatabase)
.WaitFor(sqlDatabase)
.WithReference(blobs)
.WaitFor(blobs);
builder.Build().Run();

The app consists of a single service, VolumeMount.BlazorWeb, that is configured with a SQL Server container instance via the AppHost project. PostgreSQL and Azure Storage data services are also configured in the AppHost and Blazor projects for demonstration and experimentation purposes. This Blazor Web app has been setup to use ASP.NET Core Identity for local user account registration and authentication, including Blazor identity UI. Using a persistent volume means that user accounts created when running locally are persisted across launches of the app.

The app also includes a standard class library project, VolumeMount.ServiceDefaults, that contains the service defaults used by the service project.

  1. If using the Aspire CLI, run aspire run from this directory.

    If using VS Code, open this directory as a workspace and launch the VolumeMount.AppHost project using either the Aspire or C# debuggers.

    If using Visual Studio, open the solution file VolumeMount.slnx and launch/debug the VolumeMount.AppHost project.

    If using the .NET CLI, run dotnet run from the VolumeMount.AppHost directory.

  2. Navigate to the URL for the VolumeMount.BlazorWeb from the dashboard.

  3. From the home page, click the "Register" link and enter a email and password to create a local user:

  4. After a short while (5-15s) an error page will be displayed stating that the database is not initialized and suggesting that EF Core migration be run. Click the "Apply Migrations" button and once the button text changes to "Migrations Applied", refresh the browser and confirm the form resubmission when prompted by the browser:

  5. A page will be shown confirming the registration of the account and a message detailing that a real email sender is not registered. Find and click the link at the end of the message to confirm the created account:

  6. Verify that the email confirmation page is displayed, indicating that the account is now registered and can be used to login to the site, and then click on the "Login" link in the left-hand navigation menu:

  7. Enter the email and password you used in the account registration page to login:

  8. Once logged in, click the "Logout" link in the left-hand navigation menu to log out of the site, and then stop the app, followed by starting it again, and verifying that the account you just created can still be used to login to the site once restarted, indicating that the database was using the persistent volume to store the data. You can verify the named volume existance using the Docker CLI too (docker volume ls):

    Terminal window
    > docker volume ls -f name=sqlserver
    DRIVER VOLUME NAME
    local volumemount.apphost-305a028ab1-sqlserver-data
Preview

Sample screenshots

Select an image to zoom in.

Screenshot of the account login page on the web front
Screenshot of the account login page on the web front
Screenshot of the account registration page on the web front end
Screenshot of the account registration page on the web front end
Screenshot of the database operation failed error page
Screenshot of the database operation failed error page
Screenshot of the account registration confirmation page
Screenshot of the account registration confirmation page
Screenshot of the email confirmation page
Screenshot of the email confirmation page
Screenshot of the login page
Screenshot of the login page