We have moved!

You are currently looking at documentation for Umbraco 8 and older versions.
An automated guess is that docs.umbraco.com/umbraco-cms/fundamentals/setup/server-setup/azure-web-apps could be the link to the new documentation for Umbraco 9 and newer versions.

    Running Umbraco on Azure Web Apps

    This section describes best practices with running Umbraco on Azure Web Apps

    What are Azure Web Apps

    They have been called a few names in the past, many people still know Azure Web Apps as Azure Web Sites.

    App Service is a fully Managed Platform for professional developers that brings a rich set of capabilities to web, mobile and integration scenarios. Quickly create and deploy mission critical web Apps that scale with your business by using Azure App Service.

    You can read more about them here

    Umbraco will run on Azure Web Apps but there are some configuration options and specific Azure Web Apps environment limitations you need to be aware of.

    Recommended configuration

    You need to add these appSettings:

    <add
        key="Umbraco.Core.MainDom.Lock"
        value="SqlMainDomLock" />
    <add
        key="Umbraco.Core.LocalTempStorage"
        value="EnvironmentTemp" />
    <add
        key="Umbraco.Examine.LuceneDirectoryFactory"
        value="Examine.LuceneEngine.Directories.SyncTempEnvDirectoryFactory, Examine" />
    

    The Umbraco.Core.MainDom.Lock setting is for Umbraco 8.6+. Having this setting for versions between 8.0-8.5 will not have any affect. It is recommended to use 8.6+ when running Umbraco on Azure Web Apps since this setting will prevent file locking issues.

    The minimum recommended Azure SQL Tier is "S2", however noticeable performance improvements are seen in higher Tiers

    If you are load balancing or require the scaling ("scale out") ability of Azure Web Apps then you need to consult the Load Balancing documentation since there is more that needs to be configured to support scaling/auto-scaling.

    Storage

    It is important to know that Azure Web Apps uses a remote file share to host the files to run your website (i.e. the files running your website do not exist on the machine running your website). In many cases this isn't an issue but it can become one if you have a large amount of IO operations running over remote file share.

    Scaling

    If you require the scaling ("scale out") ability of Azure Web Apps then you need to consult the Load Balancing documentation since there is a lot more that needs to be configured to support scaling/auto-scaling.

    Web worker migrations

    It's important to know that Azure Web Apps may move your website between their 'workers' at any given time. This is normally a transparent operation but in some cases you may be affected by it if any of your code or libraries use the following variables:

    • Environment.MachineName (or equivalent)
    • HttpRuntime.AppDomainAppId (or equivalent)

    When your site is migrated to another worker, these variables will change. You cannot rely on these variables remaining static for the lifetime of your website.