Add an AWS NGINX Instance
You can use F5 NGINX Controller to deploy and manage NGINX instances on Amazon Web Services (AWS).
This tutorial explains how to deploy NGINX Plus on AWS by defining an AWS Integration, a Location, and an Instance Template in NGINX Controller.
You are responsible for applying software and security updates on your data plane Instances. NGINX Controller does not manage these updates for you.
Integrations give NGINX Controller permission to deploy and manage NGINX instances on external systems, such as cloud providers like AWS.
To create an Integration for AWS, you need to configure an AWS IAM user with the following roles:
"ec2:*Instance*",
"ec2:*Tags*"In addition, you’ll need to copy and save the following AWS security credentials to use when creating an AWS Integration:
- access key ID
- secret access key ID
To create an AWS Integration, take the following steps:
- Open the NGINX Controller user interface and log in.
- Select the NGINX Controller menu icon, then select Platform.
- On the Platform menu, select Integrations.
- On the Integrations menu, select the Create Integration quick action.
- Add a name.
- (Optional) Add a display name.
- (Optional) Add a description.
- (Optional) Add tags.
- In the Integration Type list, select AWS_INTEGRATION.
- (Optional) Add the service endpoint URI.
- In the Credential Type list, select AWS_ACCESS_KEY.
- Add the access key ID.
- Add the secret access key ID.
- Select Submit.
After you’ve created an Integration for AWS, the next step is to create a Location. Locations are a way to logically group your NGINX Plus instances by their physical locations.
To create a Location, take the following steps:
- Open the NGINX Controller user interface and log in.
- Select the NGINX Controller menu icon, then select Infrastructure.
- On the Infrastructure Menu, select Locations.
- Select Create.
- Add a name for the Location.
- (Optional) Add a display name.
- In the Type list, select AWS_LOCATION.
- In the Integration References list, select the AWS Integration(s) to associate with the Location.
- Add the AWS VPC ID.
- Add the AWS region.
- (Optional) Add a description.
- (Optional) Add tags.
- (Optional) Add a description.
- (Optional) Add tags.
- Select Submit.
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.
To create an Instance Template for AWS NGINX instances, take the following steps:
- Open the NGINX Controller user interface and log in.
- Select the NGINX Controller menu icon, then select Infrastructure > Instance Templates.
- Select Create Instance Template.
- Add a name.
- (Optional) Add a display name.
- (Optional) Add a description.
- (Optional) Add tags.
- Select a Location in the list, or select Create New to create a Location.
- In the Type list, select AWS_INSTANCE_TEMPLATE.
- Add the Amazon Machine Image ID.
- Add the EC2 Instance Type.
- Add the Subnet ID.
- (Optional) Add the Security Group IDs.
- (Optional) Add the AWS Public Key.
- Specify whether a public IP address should be assigned to the instance.
- Select Submit.
Enabling WAF via the App Security add-on is not supported when deploying Instances with an Instance Template.
To create an Instance Template for AWS NGINX instances, take the following steps:
- Open the NGINX Controller user interface and log in.
- Select the NGINX Controller menu icon, then select Infrastructure > Instance Templates.
- Select Create Instance Template.
- Add a name.
- (Optional) Add a display name.
- (Optional) Add a description.
- (Optional) Add tags.
- Select a Location in the list, or select Create New to create a Location.
- In the Type list, select AWS_INSTANCE_TEMPLATE.
- Add the Amazon Machine Image ID.
- Add the EC2 Instance Type.
- Add the Subnet ID.
- (Optional) Add the Security Group IDs.
- (Optional) Add the AWS Public Key.
- Specify whether a public IP address should be assigned to the instance.
- Select Submit.
Enabling WAF via the App Security add-on is not supported when deploying Instances with an Instance Template.
Now that you’ve defined a Location and made an Instance Template for an NGINX instance on AWS, you’re ready to add the instance to NGINX Controller.
To add an AWS Instance to NGINX Controller, take the following steps:
- Open the NGINX Controller user interface and log in.
- Select the NGINX Controller menu icon, then select Infrastructure.
- On the Infrastructure menu, select Instances.
- On the Instances overview page, select Create.
- Select Create a new instance using a template.
- Add a name.
- Select a Location.
- Select an Instance Template.
- Select Submit.
When deploying an NGINX Plus instance, the deployment may fail because the Controller Agent install script doesn’t download. When this happens, an error similar to the following is logged to /var/log/agent_install.log: “Failed to download the install script for the agent.”
Take the following steps to troubleshoot the issue:
- Ensure that ports 443 and 8443 are open between NGINX Controller and the network where the NGINX Plus instance is being deployed.
- Verify that you can communicate with NGINX Controller from the NGINX Plus instance using the NGINX Controller FQDN that you provided when you installed NGINX Controller.
- If you’re deploying an NGINX Plus instance on Amazon Web Services using a template, ensure that the Amazon Machine Image (AMI) referenced in the instance_templatehas a cURL version of 7.32 or newer.
- 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.6, 3.7, 3.8, 3.9, 3.10, 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.