Edit

Share via


Community Toolkit Python hosting extensions

Includes: Hosting integration included Hosting integration only — Client integration not included Client integration not included

Note

This integration is part of the Aspire Community Toolkit and isn't officially supported by the Aspire team.

In this article, you learn about the Aspire Community Toolkit Python hosting extensions package which provides extra functionality to the Aspire Python hosting package. The extensions package lets you run Uvicorn and uv applications.

Hosting integration

To get started with the Aspire Community Toolkit Python hosting extensions, install the 📦 CommunityToolkit.Aspire.Hosting.Python.Extensions NuGet package in the AppHost project.

dotnet add package CommunityToolkit.Aspire.Hosting.Python.Extensions

For more information, see dotnet add package or Manage package dependencies in .NET applications.

Example usage

The following sections detail various usages, from running Uvicorn applications to using specific package managers such as uv.

To work with Python apps, they need to be within a virtual environment. To create a virtual environment, refer to the Initialize the Python virtual environment section.

The UVICORN_PORT environment variable is used to determine the port the Uvicorn application should listen on. By default, this port is randomly assigned by Aspire. The name of the environment variable can be changed by passing a different value to the WithHttpEndpoint method.

In the AppHost.cs file of your AppHost project, call the AddUvicornApp method to add a Uvicorn application to the builder.

var builder = DistributedApplication.CreateBuilder(args);

var uvicorn = builder.AddUvicornApp(
        name: "uvicornapp",
        projectDirectory: "../uvicornapp-api",
        appName: "main:app"
    )
    .WithHttpEndpoint(env: "UVICORN_PORT");

builder.Build().Run();

The Uvicorn application can be added as a reference to other resources in the AppHost project.

See also