Welcome TTP 1.4.2 Latest Version.
Thunder Terraform Provider is a custom plugin to configure thunder using terraform as a IaC tool and terraform scripts[.tf] simplifies applying configuration on thunder. You can configure or de-configure thunder settings.
This plugin contains several configurations of thunder which can be applied via out of box examples provided. Terraform provider plugin will only configure thunder via axapi, It will not install thunder.
ACOS | TTP 1.0.0 | TTP 1.1.0 | TTP 1.2.1 | TTP 1.2.2 | TTP 1.3.0 | TTP 1.4.1 | TTP 1.4.2 |
---|---|---|---|---|---|---|---|
ACOS version 6.0.2-p1 |
No |
No |
No |
No |
No |
Yes |
Yes |
ACOS version 6.0.1 |
No |
No |
Yes |
Yes |
Yes |
No |
No |
ACOS version 6.0.0-p2 |
No |
No |
Yes |
Yes |
Yes |
No |
No |
ACOS version 6.0.0-p1 |
No |
No |
Yes |
Yes |
Yes |
No |
No |
ACOS version 5.2.1-p6 |
No |
Yes |
No |
No |
No |
No |
No |
ACOS version 5.2.1-p5 |
No |
Yes |
No |
No |
No |
No |
No |
ACOS version 5.2.1-p4 |
Yes |
No |
No |
No |
No |
No |
No |
ACOS version 5.2.1-p3 |
Yes |
No |
No |
No |
No |
No |
No |
- Restructured docs folder for easy navigation
- Support for ACOS v6.0.2-p1
- Supports total 2712 resources with examples
-
Support for ACOS v6.0.1
-
Jenkins and Tekton integration examples
-
Additional resources:
- Cloud Services Cloud Provider AWS Log
- Cloud Services Cloud Provider Azure Log
- Cloud Services Cloud Provider VMware Log
- Cloud Services Cloud Provider AWS Metrics
- Cloud Services Cloud Provider Azure Metrics
- Cloud Services Cloud Provider VMware Metrics
- Service Partition
- System App Performance Stats
- System Throughput Stats
- System Memory Oper
- System Hardware Oper
- Interface Available Eth List Oper
- Sessions Oper
- Plat CPU Packet Oper
- SLB HTTP Proxy Oper
- SLB SSL Stats Oper
- SLB Server Oper
- Clock Show Oper
- Syslog Oper
- Support for MAC M1 processors
- Support for ACOS 6.0.0-p1 and ACOS 6.0.0-p2
- Fixed Change Optional to Required for partition, slb server, and slb service-group
- Defect Fixtures
- Support for ACOS 6.0.0-p1
- Defect Fixtures
- Extended Support for GSLB AXAPIs
- Extended Support for Geo-Location AXAPIs
- Extended Support for Password Change AXAPIs
- Defect Fixtures
- Install terraform on your local OS, Please refer below sections for more details.
- Search required terraform configuration from examples. In case not found create a new one, Please refer below sections for more details.
- Execute terraform scripts to apply thunder configuration, Please refer below sections for more details.
- Verify thunder configuration after terraform apply, Please refer below sections for more details.
To install Terraform on Ubuntu, perform the following steps:
1. Run the following commands to download and install Terraform 1.5.6.
a. wget https://releases.hashicorp.com/terraform/1.5.6/terraform_1.5.6_linux_amd64.zip
b. unzip terraform_1.5.6_linux_amd64.zip
c. mv terraform /usr/local/bin/
2. Verify installation using below command:
a. terraform -version
For more information, please visit : https://www.terraform.io/downloads.html
To install Terraform on Windows, perform the following steps:
1. Download windows installable from:
https://developer.hashicorp.com/terraform/downloads
https://releases.hashicorp.com/terraform/1.5.6/terraform_1.5.6_windows_386.zip
https://releases.hashicorp.com/terraform/1.5.6/terraform_1.5.6_windows_amd64.zip
2. Extract at C:/Terraform1.5.6
3. Update environment variable 'path and add 'C:/Terraform1.5.6/'
For more information, please visit: https://developer.hashicorp.com/terraform/downloads
To install Terraform on MacOS, perform the following steps:
Run the following commands to download and install the latest version of Terraform:
1. brew tap hashicorp/tap
2. brew install hashicorp/tap/terraform
For more information, please visit: https://developer.hashicorp.com/terraform/downloads
To search for a Thunder Configuration in the existing examples, perform the following steps:
-
Search the required Terraform configuration script directory navigate to examples > resources directory.
Example:
If you want to apply the bgp router configuration on Thunder, search for the thunder_router_bgp directory under the resources directory.
-
Open the Terraform script from the directory.
Example:
Open resource.tf script under the thunder_router_bgp directory.
-
Update the Thunder IP address and login credentials depending on the type of Thunder installed and review the Thunder configurations in the Terraform script.
provider "thunder" {
address = var.dut9049
username = var.username
password = var.password
}
resource "thunder_router_bgp" "bgp1" {
as_number = 101
neighbor {
ipv4_neighbor_list {
neighbor_ipv4 = "10.1.1.104"
activate = 1
nbr_remote_as = 104
allowas_in = 1
allowas_in_count = 10
graceful_restart = 1
}
}
}
resource "thunder_router_bgp" "bgp2" {
provider = thunder.L3V_A
as_number = 201
neighbor {
ipv4_neighbor_list {
neighbor_ipv4 = "10.1.1.204"
activate = 1
nbr_remote_as = 204
allowas_in = 1
allowas_in_count = 10
graceful_restart = 1
}
}
}
-
Add, modify, or remove the Thunder configuration parameters and their corresponding values as appropriate.
-
Save the changes.
-
Identify the compatible Terraform Provider version for your installed ACOS version from Support Matrix Section.
-
Select your Terraform Provider version from the Latest Version drop-down.
-
Expand Resources from the left-panel to select the required Thunder configuration resource.
-
Copy and paste the following Terraform Provider configuration from the USE PROVIDER drop-down to your Terraform script.
terraform {
required_providers {
thunder = {
source = "a10networks/thunder"
version = "1.4.2"
}
}
}
- Save the Terraform script.
Here are step-by-step instructions for creating a terraform thunder configuration example. For example if you want to apply bgp router configuration on thunder and which doesn't exist in examples.
- Create a new directory to house your terraform configuration files.
mkdir thunder_router_bgp
cd thunder_router_bgp
-
Create a
.tf
file, such asthunder_router_bgp.tf
, in your "thunder_router_bgp" directory. In this file, define the Thunder ROUTER BGP configurations using the A10Networks Thunder Provider. Refer to the official documentation: https://registry.terraform.io/providers/a10networks/thunder/latest/docs/resources/router_bgp for the required resource and parameters.Here is basic example:
terraform {
required_providers {
thunder = {
source = "a10networks/thunder"
version = "1.4.2" # Replace with your desired provider version
}
}
}
provider "a10networks" {
host = "10.10.10.10" # Replace with your desired your thunder device ip
username = "admin" # Replace with your desired your thunder user name
password = "password" # # Replace with your password
}
resource "thunder_router_bgp" "thunder_router_bgp" {
as_number = 101 # Replace with your desired bgp number
neighbor {
ipv4_neighbor_list {
neighbor_ipv4 = "10.1.1.104" # Replace with your desired neighbor_ipv4 address
activate = 1 # Replace with your desired activate value
nbr_remote_as = 104 # Replace with your desired nbr_remote_as value
allowas_in = 1 # Replace with your desired allowas_in value
allowas_in_count = 10 # Replace with your desired allowas_in_count value
graceful_restart = 1 # Replace with your desired graceful_restart value
}
}
}
Adjust the BGP configuration parameters as needed.
To apply the Thunder Terraform configurations using Terraform CLI, perform the following steps:
-
Go to your required Terraform configuration script directory from the command prompt.
-
If the Terraform Provider is not initialize, run the following command to initialize the working directory and download the A10 Networks Terraform Thunder Provider.
terraform init
If Terraform Provider is already initialize with an older version, run the following command to upgrade the Terraform Provider to the latest version:
terraform init -upgrade
- Create an execution plan and ensure that it matches your desired configurations.
terraform plan
- Apply the specified configuration on your Thunder device.
terraform apply
Terraform scripts can be executed via Jenkins pipeline.
Please refer the /devops/jenkins/Jenkins Pipeline Configuration Guide.pdf
file to configure Jenkins pipeline.
This comprehensive document offers step-by-step instructions and best practices for automating TTP (Thunder Terraform Provider) configurations, ensuring efficient management within your Jenkins environment.
Terraform scripts can be executed via Tekton pipeline.
Please refer the /devops/tekton/Tekton Pipeline Configuration Guide.pdf
file to configure Tekton pipeline.
This comprehensive document offers step-by-step instructions and best practices for automating TTP (Thunder Terraform Provider) configurations, ensuring efficient management within your Tekton environment.
To verify the applied configurations, follow below steps:
-
SSH into the Thunder device using your username and password.
-
Once connected, enter the following commands:
If you have created a new example, please save the Terraform file with a resource-specific name, such as "thunder_bgp.tf."
- Clone the repository.
- Copy the newly created file and place it under the /examples/resource directory.
- Create a MR against the master branch.
$ git clone [email protected]:a10networks/terraform-provider-thunder.git
$ cd terraform-provider-thunder
$ make build
After building new provider we need to install and test the plugin.
We need to create a new version please follow below step.
- $ cd terraform-provider-thunder
- $ go build -o terraform-provider-thunder
- $ mkdir -p ~/.terraform.d/plugins/a10networks.com/a10networks/thunder/7.7.7/linux_amd64/
- $ cp terraform-provider-thunder ~/.terraform.d/plugins/a10networks.com/a10networks/thunder/7.7.7/linux_amd64/
- create version.tf file like:
terraform {
required_providers {
thunder = {
source = "a10networks.com/a10networks/thunder"
version = "7.7.7"
}
}
}
If you face some dependency issue try $ go mod tidy
or $ go mod vendor
Note: After cloning you can also run $ make local
to perform these above step automatically for dummy version 7.7.7 in Linux env. Else if you have already executed manual steps please ignore this.
If raise MR request for contributing.
Terraform provider documentation is available at https://registry.terraform.io/providers/a10networks/thunder/latest/docs
A10 Thunder AXAPI support documentation available at https://documentation.a10networks.com/docs/IaC/Terraform/thunder-terraform-provider/1-4-1/
Please raise issue in github repository. Please include the Terraform script that demonstrates the bug and the command output and stack traces will be helpful.
Please reach out at [email protected] with "a10-terraform-provider" in the subject line.