README
¶
dd-cloud-compute-terraform
Terraform provider for Dimension Data cloud compute.
Currently, the following resource types are supported:
ddcloud_networkdomain
: A network domainddcloud_vlan
: A VLANddcloud_server
: A virtual machineddcloud_server_anti_affinity
: An anti-affinity rule between 2 serversddcloud_nat
: A NAT rule (forwards traffic from a public IPv4 address to a server's internal IPv4 address)ddcloud_firewall_rule
: A firewall ruleddcloud_vip_node
: A Virtual IP (VIP) node.ddcloud_vip_pool
: A Virtual IP (VIP) pool.ddcloud_vip_pool_member
: A Virtual IP (VIP) pool membership (node -> pool).
For more information, see the provider documentation.
Installing the provider
Download the latest release and place the provider executable in the same directory as the main Terraform executable.
Building the provider yourself
If you want to build the provider yourself instead of installing a pre-built release:
- On windows, run
./build.ps1
, then create / update$HOME\terraform.rc
- On Linux / OSX, run
./build.sh
, create / update~/.terraformrc
And add the following contents:
providers {
ddcloud = "path-to-the-folder/containing/dd-cloud-compute-terraform/_bin/terraform-provider-ddcloud"
}
Testing the provider
Create a folder containing a single .tf
file:
/*
* This configuration will create a single server running CentOS and expose it to the internet on port 80.
*
* By default, the CentOS image does not have http installed (`yum install httpd`) so there's no problem exposing port 80.
*/
provider "ddcloud" {
# User name and password can also be specified via DD_COMPUTE_USER and DD_COMPUTE_PASSWORD environment variables.
"username" = "my_username"
"password" = "my_password" # Watch out for escaping if your password contains characters such as "$".
"region" = "AU" # The DD compute region code (e.g. "AU", "NA", "EU")
}
resource "ddcloud_networkdomain" "my-domain" {
name = "terraform-test-domain"
description = "This is my Terraform test network domain."
datacenter = "AU9" # The ID of the data centre in which to create your network domain.
}
resource "ddcloud_vlan" "my-vlan" {
name = "terraform-test-vlan"
description = "This is my Terraform test VLAN."
networkdomain = "${ddcloud_networkdomain.my-domain.id}"
# VLAN's default network: 192.168.17.1 -> 192.168.17.254 (netmask = 255.255.255.0)
ipv4_base_address = "192.168.17.0"
ipv4_prefix_size = 24
depends_on = [ "ddcloud_networkdomain.my-domain"]
}
resource "ddcloud_server" "my-server" {
name = "terraform-server"
description = "This is my Terraform test server."
admin_password = "password"
memory_gb = 8
cpu_count = 2
networkdomain = "${ddcloud_networkdomain.my-domain.id}"
primary_adapter_ipv4 = "192.168.17.10"
dns_primary = "8.8.8.8"
dns_secondary = "8.8.4.4"
os_image_name = "CentOS 7 64-bit 2 CPU"
# The image disk (part of the original server image). If size_gb is larger than the image disk's original size, it will be expanded (specifying a smaller size is not supported).
# You don't have to specify this but, if you don't, then Terraform will keep treating the ddcloud_server resource as modified.
disk {
scsi_unit_id = 0
size_gb = 10
}
# An additional disk.
disk {
scsi_unit_id = 1
size_gb = 20
}
depends_on = [ "ddcloud_vlan.my-vlan" ]
}
resource "ddcloud_nat" "my-server-nat" {
networkdomain = "${ddcloud_networkdomain.my-domain.id}"
private_ipv4 = "${ddcloud_server.my-server.primary_adapter_ipv4}"
# public_ipv4 is computed at deploy time.
depends_on = [ "ddcloud_vlan.my-vlan" ]
}
resource "ddcloud_firewall_rule" "my-vm-http-in" {
name = "my_server.HTTP.Inbound"
placement = "first"
action = "accept" # Valid values are "accept" or "drop."
enabled = true
ip_version = "ipv4"
protocol = "tcp"
# source_address is computed at deploy time (not specified = "any").
# source_port is computed at deploy time (not specified = "any).
# You can also specify source_network (e.g. 10.2.198.0/24) or source_address_list instead of source_address.
# For a ddcloud_vlan, you can obtain these values using the ipv4_baseaddress and ipv4_prefixsize properties.
# You can also specify destination_network or destination_address_list instead of source_address.
destination_address = "${ddcloud_nat.my-server-nat.public_ipv4}"
destination_port = "80"
networkdomain = "${ddcloud_networkdomain.my-domain.id}"
}
- Run
terraform plan -out tf.plan
. - Verify that everything looks ok.
- Run
terraform apply tf.plan
- Have a look around and, when it's time to clean up...
- Run
terraform plan -destroy -out tf.plan
- Verify that everything looks ok.
- Run
terraform apply tf.plan
Documentation
¶
There is no documentation for this package.
Click to show internal directories.
Click to hide internal directories.