App Offline file (app_offline.htm)

Note

This isn't the latest version of this article. For the current release, see the .NET 9 version of this article.

Warning

This version of ASP.NET Core is no longer supported. For more information, see the .NET and .NET Core Support Policy. For the current release, see the .NET 9 version of this article.

Important

This information relates to a pre-release product that may be substantially modified before it's commercially released. Microsoft makes no warranties, express or implied, with respect to the information provided here.

For the current release, see the .NET 9 version of this article.

The App Offline file (app_offline.htm) is used by the ASP.NET Core Module to shut down an app.

If a file with the name app_offline.htm is detected in the root directory of an app, the ASP.NET Core Module attempts to gracefully shut down the app and stop processing incoming requests. If the app is still running after the number of seconds defined in shutdownTimeLimit, the ASP.NET Core Module stops the running process.

While the app_offline.htm file is present, the ASP.NET Core Module responds to requests by sending back the contents of the app_offline.htm file. The app_offline.htm must be less than 4 GB. When the app_offline.htm file is removed, the next request starts the app.

When using the out-of-process hosting model, the app might not shut down immediately if there's an open connection. For example, a WebSocket connection may delay app shut down.

Locked deployment files

Files in the deployment folder are locked when the app is running. Locked files can't be overwritten during deployment.

app_offline.htm is the primary mechanism to release locked files. app_offline.htm is used by Web Deploy to properly stop and start the app.

app_offline.htm can be manually used to start and stop the app (requires PowerShell 5 or later):

$pathToApp = '{PATH TO APP}'


New-Item -Path $pathToApp -Name "app_offline.htm" -ItemType "file"

# Provide script commands here to deploy the app

Remove-Item -Path $pathToApp\app_offline.htm

In the preceding PowerShell script:

  • The placeholder {PATH TO APP} is the path to the app.
  • The New-Item command stops the app pool.
  • The Remove-Item command starts the app pool.
  • Commands between the New-Item command and the Remove-Item command are provided by the developer to deploy the app.

Files can also be unlocked by manually stopping the app pool in the IIS Manager on the server. Don't use the app_offline.htm file when using the IIS Manager to stop and restart the app pool.