Microsoft.NET.Build.Containers 8.0.103

.NET SDK Containers

This package lets you build container images from your projects with a single command.

Getting Started

To build a container from the SDK, add this package and run the publish command, specifying the DefaultContainer PublishProfile. You can learn more about Publish Profiles in the documentation.

>dotnet add package Microsoft.NET.Build.Containers
>dotnet publish --os linux --arch x64 -p:PublishProfile=DefaultContainer
...
Pushed container '<your app name>:<your app version>' to registry 'docker://'
...

Out of the box, this package will infer a number of properties about the generated container image, including which base image to use, which version of that image to use, and where to push the generated image. You have control over all of these properties, however. You can read more about these customizations here.

Note: This package only supports Web projects (those that use the Microsoft.NET.Sdk.Web SDK) in this version.

No packages depend on Microsoft.NET.Build.Containers.

# Microsoft.NET.Build.Containers 8.0.100 This version brings the following new features and enhancements: * For .NET 8-targeting applications, the generated container user will not have root permissions by default. This is a breaking change from previous versions, but it is a more secure default. If you need to run your container as root, you can set the `ContainerUser` property to `root` in your project file. Note also that in .NET 8 several changes were made to the Microsoft .NET base images, like changing the default ASP.NET port to 8080, so applications newly-targeting .NET may have to adjust to these settings. * Generated container images now default to using the `latest` tag instead of the value of the MSBuild `Version` property, to align with other container tooling. You can still override this behavior by setting the `ContainerTag` property in your project file. * The `ContainerFamily` property was added to support choosing from different variants of image tags without needing to specify the entire base image. For example, to target Alpine Linux you can now set `ContainerFamily` to `alpine`. * The generated images will now correctly set `User` and `ExposedPort` metadata based on well-known .NET Environment variables for these settings. * We now support using base images that set `Entrypoint` instead of `Cmd`. The previous `ContainerEntrypoint` and `ContainerEntrypointArgs` properties are still supported, but will log a warning when used. You should now use `ContainerAppCommand` and `ContainerAppCommandArgs` instead to set the desired start application - these properties allow the tooling to select the proper app start command based on the base images' use of Entrypoint or Cmd. Thanks to @tmds for this functionality! * We explicitly support using podman as a local destination for your containers. If `podman` is present on the system and `docker` is not, we will opt to use `podman` instead. If you'd like to make this behavior explicit you can set `LocalRegistry` to either `docker` or `podman`. Thanks to @tmds for this contribution! * Permissions for files in the images not don't have the executable bit set unless it is necessary. * Support for authenticating using Identity Token flows was added. This unblocks support for Azure Managed Identities, as well as all other registries where the result of `docker login <registry url>` is an Identity Token instead of an Access Token or Username/Password pair.

.NET 8.0

  • No dependencies.

Version Downloads Last updated
9.0.200-preview.0.24575.35 0 12/10/2024
9.0.102 0 01/14/2025
9.0.101 0 12/03/2024
9.0.100 0 11/12/2024
9.0.100-rc.2.24474.11 0 10/08/2024
9.0.100-rc.1.24452.12 0 09/10/2024
9.0.100-preview.7.24407.12 0 08/13/2024
9.0.100-preview.6.24328.19 0 07/09/2024
9.0.100-preview.5.24307.3 0 06/11/2024
9.0.100-preview.4.24267.43 0 05/21/2024
9.0.100-preview.3.24204.14 1 04/20/2024
9.0.100-preview.2.24157.36 1 04/20/2024
9.0.100-preview.1.24101.1 1 04/19/2024
8.0.405 0 01/14/2025
8.0.404 0 11/12/2024
8.0.403 0 10/08/2024
8.0.402 0 09/24/2024
8.0.401 0 08/15/2024
8.0.400 0 08/13/2024
8.0.308 0 01/14/2025
8.0.307 0 11/12/2024
8.0.306 0 10/08/2024
8.0.304 0 08/13/2024
8.0.303 0 07/09/2024
8.0.302 0 06/11/2024
8.0.301 0 05/28/2024
8.0.300 0 05/14/2024
8.0.206 0 05/28/2024
8.0.205 0 05/14/2024
8.0.204 1 04/19/2024
8.0.202 1 04/20/2024
8.0.200 1 04/18/2024
8.0.112 0 01/14/2025
8.0.111 0 11/12/2024
8.0.110 0 10/08/2024
8.0.108 0 08/13/2024
8.0.107 0 07/09/2024
8.0.106 0 05/28/2024
8.0.105 0 05/14/2024
8.0.104 2 04/18/2024
8.0.103 1 04/20/2024
8.0.102 1 04/20/2024
8.0.101 1 04/20/2024
8.0.100 1 04/18/2024
8.0.100-rc.2.23480.5 2 04/19/2024
8.0.100-rc.1.23462.41 2 04/19/2024
8.0.100-rc.1.23455.21 2 04/19/2024
8.0.100-preview.7.23376.5 1 04/18/2024
8.0.100-preview.6.23330.7 1 04/20/2024
8.0.100-preview.5.23303.1 1 04/18/2024
8.0.100-preview.4.23260.11 1 04/18/2024
7.0.410 0 05/28/2024
7.0.409 0 05/14/2024
7.0.408 1 04/20/2024
7.0.407 1 04/19/2024
7.0.406 1 04/19/2024
7.0.405 1 04/20/2024
7.0.404 1 04/19/2024
7.0.403 1 04/20/2024
7.0.402 1 04/18/2024
7.0.401 1 04/19/2024
7.0.400 1 04/19/2024
7.0.317 0 05/28/2024
7.0.316 0 05/14/2024
7.0.315 1 04/19/2024
7.0.314 1 04/20/2024
7.0.313 1 04/19/2024
7.0.312 1 04/19/2024
7.0.311 1 04/19/2024
7.0.310 1 04/20/2024
7.0.309 1 04/18/2024
7.0.308 1 04/20/2024
7.0.307 1 04/20/2024
7.0.306 3 08/18/2023
7.0.305 1 04/19/2024
7.0.304 1 04/19/2024
7.0.302 1 04/20/2024
0.4.0 1 04/20/2024
0.3.2 1 04/19/2024
0.2.7 0 10/27/2022
0.1.8 1 04/19/2024