Add an Azure NGINX Instance
You can use F5 NGINX Controller to deploy and manage NGINX instances on Microsoft Azure.
This tutorial explains how to deploy NGINX Plus on Azure by defining an Azure Integration, a Location, and an Instance Template in NGINX Controller.
You are responsible for applying software and security updates on your NGINX instances. NGINX Controller does not manage these updates for you.
Before you can create an Azure Integration in NGINX Controller, you need to register an app in Azure and create a client secret. You’ll need to copy and save the following information to use when creating an Azure Integration:
- Application (client) ID
- Directory (tenant) ID
- Client secret value
To register an app in Azure, take the following steps:
- 
Sign in to the Microsoft Azure Portal. 
- 
Search for and select Microsoft Entra. 
- 
Under Manage, select App registrations > New registration. 
- 
Type a name to use for the app. 
- 
Specify who can see the app. 
- 
Select Register. The overview page for the app is displayed. 
- 
On the app overview page, copy and save the following information: - Application (client) ID
- Directory (tenant) ID
 
To add a client secret to your app registration:
- Select your application in App registrations in the Azure portal.
- Select Certificates & secrets > New client secret.
- Add a description for your client secret.
- Select a duration.
- Select Add.
- Copy and save the secret’s value for use when creating an Azure Integration in NGINX Controller – this value is never displayed again after leaving this page.
Integrations give NGINX Controller permission to deploy and manage NGINX instances on external systems, such as cloud providers like Azure.
To create an Integration for Azure using the NGINX Controller API, send a POST request similar to the following example to the Integrations API endpoint.
In the JSON request, provide the clientID, tenantID, and clientSecret that you copied and saved when you registered an app with Azure.
{
  "metadata": {
    "name": "azure"
  },
  "desiredState": {
    "credential": {
      "type": "AZURE_SERVICE_PRINCIPAL",
      "clientID": "...",
      "clientSecret": "...",
      "tenantID": "..."
    },
    "type": "AZURE_INTEGRATION"
  }
}
After you’ve created an Integration for Azure, take the following steps to create a Location. Locations are a way to logically group your NGINX Plus instances by their physical locations. The Location you define in NGINX Controller corresponds to the Azure location that your resource group is running in.
To create a Location, you’ll need your Azure resource group name, region, and subscription ID. To gather this information:
- 
Sign in to the Microsoft Azure Portal. 
- 
Search for and select Resource groups. 
- 
Select the name of your resource group. Make a note of this name to use for later. 
- 
Under Essentials, copy and save the following information: - Subscription ID
- Location
 
To create a Location using the NGINX Controller API, send a POST request similar to the following example to the Locations API endpoint.
In the JSON request, provide the resourceGroup name, region, and subscriptionID that you copied and saved in the previous steps.
{
  "metadata": {
    "name": "washington",
    "tags": []
  },
  "desiredState": {
    "type": "AZURE_LOCATION",
    "integrationRef": {
      "ref": "/platform/integrations/azure"
    },
    "resourceGroup": "...",
    "region": "...",
    "subscriptionID": "..."
  }
}
An Instance Template defines the parameters to use when creating an NGINX instance. Instance Templates are ideal for cloud orchestration and make managing your cloud resources easy and quick.
For the Instance Template, you can provide the details for an NGINX image on the Azure Marketplace, or you can provide the image and network details for your own instance. Refer to the NGINX Controller Technical Specifications guide for the NGINX Plus requirements.
- 
To create an Instance Template for an Azure Marketplace image using the NGINX Controller REST API, send a POST request similar to the following example to the Instance Templates API endpoint. You can find descriptions of the instance parameters in the API Reference documentation. To look up the image details —publisher,offer,sku, andversion— that you’ll need to define the Instance Template, you can attempt to deploy an NGINX instance from the Azure Marketplace and look at the template that Azure creates to get the image details.json{ "metadata": { "name": "us-west-azure" }, "desiredState": { "type": "AZURE_INSTANCE_TEMPLATE", "image": { "type": "AZURE_IMAGE_REFERENCE", "publisher": "nginxinc", "offer": "nginx-plus-v1", "sku": "nginx-plus-ub1804", "version": "latest" }, "instanceType": "Standard_A1", "adminUser": "azureuser", "publicKey": "<the complete ssh-rsa string>", "networkInterface": { "type": "AZURE_NIC_CONFIG", "name": "", "virtualNetwork": "", "subnet": "default", "securityGroup": "", "publicIpName": "" } } }
- 
To create an Azure Instance Template for your own instance using the [NGINX Controller REST API](https://frontdoor-test-docs.nginx.com/previews/docs/1108/nginx-controller/api/reference/, send a POST request similar to the following example to the Instance Templates API endpoint. json{ "metadata": { "name": "my-azure-template-for-standard-A1", }, "desiredState": { "type": "AZURE_INSTANCE_TEMPLATE", "image": { "type": "AZURE_IMAGE_ID", "imageID": "<the resource ID for the Azure image>" }, "instanceType": "Standard_A1", "adminUser": "azureuser", "publicKey": "<the complete ssh-rsa string>", "networkInterface": { "type": "AZURE_NIC_ID", "nicID": "<the ID for the Azure network interface>" } } }
Now that you’ve defined a Location and made an Instance Template for an NGINX instance on Azure, you’re ready to add the instance to NGINX Controller.
To add an Azure NGINX instance to NGINX Controller using the NGINX Controller REST API, send a POST request similar to the following example to the Instances API endpoint. For the templateRef parameter, use the Instance Template that you created in the previous procedure.
{
  "metadata": {
    "name": "azure1"
  },
  "desiredState": {
    "type": "AZURE_INSTANCE",
    "templateRef": {
      "ref": "/infrastructure/locations/washington/instance-templates/us-west-azure"
    }
  }
}
- Manage Your NGINX Instances
- Add, Edit, and Update Locations
- View Performance Reports for Your Instances
- Deploy an App
This documentation applies to the following versions of NGINX Controller: 3.12, 3.13, 3.14, 3.15, 3.16.1, 3.17, 3.18, 3.18.1, 3.18.2 and 3.18.3.
This documentation applies to the following versions of NGINX Controller API Management module: 3.18, 3.18.1, 3.19, 3.19.1, 3.19.2, 3.19.3, 3.19.4 and 3.19.5.
This documentation applies to the following versions of NGINX Controller App Delivery module: 3.20, 3.20.1, 3.21, 3.22, 3.22.1, 3.22.2, 3.22.3, 3.22.4, 3.22.5, 3.22.6, 3.22.7 and 3.22.8.