Skip to main content

Azure Functions deployments

Harness now supports the deployment of Azure Functions, enabling you to automate and manage serverless function deployments to Azure with ease.

note

Currently, this feature is behind the feature flag CDS_AZURE_FUNCTION. Contact Harness Support to enable the feature.

This topic walks you through setting up and running an Azure Functions deployment in Harness.

The basic steps are:

  1. Specify the Azure Function artifact and configuration required for the function.
  2. Connect Harness with your Azure subscription.
  3. Define the target function in Harness and install a Harness Delegate to perform the deployment.
  4. Define the steps for the different deployment strategies:
    • Basic: In a Basic deployment, all nodes(pods, instances, etc) within a single environment are replaced at the same time with new nodes containing the new service/artifact version.

Azure Function pipeline stages

Azure deployments are performed using a CD stage with the deployment type Azure Function.

For more information on stages, go to Add a Stage and CD Pipeline modeling overview.

Azure Function Services

In Harness, the service represents your Azure Function.

You define the service for your deployment in the service settings of the pipeline stage. You can either define the service separately in your project's service section and select it in the stage, or create the service directly within the stage's service tab.

It is an artifact-based service, where a manifest is not required, and setting up Variables is optional.

Info

The artifact must contain the Azure function app. For more information on how to create containerized function apps, go to Azure Documentation.

You can also deploy Azure Function Apps packaged as ZIP Bundles. For more information, refer to Azure Documentation.

Important: When creating the Function App in Azure, ensure that you select the Container Apps Environment hosting plan. This is essential for deploying containerized Function Apps

To add an artifact source, click on Add Artifact Source.

Currently, Harness supports Docker Registry, ACR, Nexus3, and Artifactory for artifact repositories. Choose where your artifact is stored, and click Continue.

Under Artifact Repository, configure your connector to connect to your artifact repository.

Under Artifact Location, specify the necessary details such as Artifact Source Identifier, Image Path, Tag, and click Submit.

You can also create and use a template for artifacts.

Azure Function Environments

Define the environment you want to use to deploy the Azure function.

You define the target infrastructure for your deployment in the Environment settings of the pipeline stage. You can either define the environment separately in your project's Environments section and select it in the stage, or create the environment directly within the stage's Environment tab.

Azure Functions target infrastructure

For deploying Azure Functions, you need to specify the pre-existing target infrastructure:

For details on Harness provisioning, go to Provisioning overview.

Pre-existing infrastructure

The target Azure environment for your Harness Azure Function deployment is defined in a Harness Environment's Infrastructure. You will provide the Azure Function name later in your stage's Execution.

You simply provide select or create an Azure Cloud Provider connector and then select the Azure Function's Subscription Id and Resource Group.

In your stage Environment, in Specify Infrastructure, you select an infrastructure or select New Infrastructure and define the infrastructure settings:

  • Connector: Select or create an Azure Cloud Provider connector that connects to your Azure application and tenant Ids.

    For steps on setting up a new Azure Cloud Provider connector, go to Add a Microsoft Azure Cloud Connector.

  • Subscription Id: Select the Azure subscription used by your Azure Function.

    The subscription is located in the Azure Function Overview section of the Azure portal.

  • Resource Group: Select the resource group used by your Azure Function.

    The resource group is located in the Azure Function Overview section of the Azure portal.

Within the same resource group, you can't mix Windows and Linux apps in the same region. See Limitations from Azure.

When you're done, infrastructure will look something like this:

note

In the deploy steps under Container Configuration, specify the appropriate image based on your container registry:

  1. ECR Image for azure function plugin
  2. Docker Image for azure function plugin

Azure function Deploy

In the execution tab of the pipeline stage, select Add Step and select Azure function Deploy.

Currently Azure function deployment supports basic and custom deployment strategy.

The Azure function Deploy step has the following settings:

  • Name: Enter a name for the step.
  • Timeout: Enter a minimum of 10m. The slot deployment relies on Azure and can take time.
  • Azure Connector: Specify the connector that connects to the azure infrastructure.
  • Image: Specify the artifact image you want to run.
  • Function app: Specify the Azure Container to be used.
  • Deployment Slot: Enter the name of the Source slot for the deployment. This slot is where Harness deploys the new Azure Function version. Make sure the slot you enter is running.

Additionally you can have optional configurations such as

  • Pre-Execution Command: A command that runs before the main execution starts.
  • Image Pull Policy: Specifies when the container image should be pulled from the registry.
  • Run as User: Configures the user identity under which the function or container should run, useful for security and access control.
  • Limit Memory: Defines the maximum memory that can be allocated to the container or function during execution.
  • Limit CPU: Sets a limit on the CPU usage for the function or container, ensuring the function does not consume excessive resources.
  • Deploy Command Options: Options that can be passed to customize the deployment process
  • Environment Variables Additional environment variables that you need to specify.

Azure Function Rollback

Harness will try to recover the state before deployment.

For a Docker image deployment rollback, Harness will fetch the Web App details (artifact, app settings, connection strings, startup script) of the existing slot and use this data to bring the slot to its previous state.

For non-containerized artifact rollback, Harness will rollback to the last successful deployment done with Harness. Harness saves deployment details after a successful deployment and uses this data for rollback in the next deployment.

The Azure Function Rollback step has the following settings:

  • Name: Enter a name for the step.
  • Timeout: Enter a minimum of 10m. The slot deployment relies on Azure and can take time.
  • Azure Connector: Specify the connector that connects to the azure infrastructure.
  • Image: Specify the artifact image you want to deploy.

Additionally you can have optional configurations such as

  • Image Pull Policy: Specifies when the container image should be pulled from the registry.
  • Run as User: Configures the user identity under which the function or container should run, useful for security and access control.
  • Limit Memory: Defines the maximum memory that can be allocated to the container or function during execution.
  • Limit CPU: Sets a limit on the CPU usage for the function or container, ensuring the function does not consume excessive resources.

Azure Function Deployment Sample

To see an example of how to deploy Azure Functions using Harness, visit the Harness Community Repository.

This repository provides a ready-to-use sample application and the necessary configuration files to help you get started quickly.