diff --git a/examples/2-vms-loadbalancer-lbrules/deploy.ci.sh b/examples/2-vms-loadbalancer-lbrules/deploy.ci.sh index 57e0dc9b1a42..64a0063720c9 100755 --- a/examples/2-vms-loadbalancer-lbrules/deploy.ci.sh +++ b/examples/2-vms-loadbalancer-lbrules/deploy.ci.sh @@ -18,7 +18,7 @@ docker run --rm -it \ # cleanup deployed azure resources via azure-cli docker run --rm -it \ - azuresdk/azure-cli-python \ + azuresdk/azure-cli-python:0.2.10 \ sh -c "az login --service-principal -u $ARM_CLIENT_ID -p $ARM_CLIENT_SECRET --tenant $ARM_TENANT_ID > /dev/null; \ az network lb show -g $KEY -n rglb; \ az network lb rule list -g $KEY --lb-name rglb;" diff --git a/examples/cdn-with-storage-account/README.md b/examples/cdn-with-storage-account/README.md index 8d2d0377caa3..53f83df7438f 100644 --- a/examples/cdn-with-storage-account/README.md +++ b/examples/cdn-with-storage-account/README.md @@ -26,3 +26,5 @@ If you are committing this template to source control, please insure that you ad ## variables.tf The `variables.tf` file contains all of the input parameters that the user can specify when deploying this Terraform template. + +![graph](/examples/azure-cdn-with-storage-account/graph.png) \ No newline at end of file diff --git a/examples/encrypt-running-linux-vm/deploy.ci.sh b/examples/encrypt-running-linux-vm/deploy.ci.sh index c85e3aea7136..275a7a8a202b 100755 --- a/examples/encrypt-running-linux-vm/deploy.ci.sh +++ b/examples/encrypt-running-linux-vm/deploy.ci.sh @@ -7,8 +7,6 @@ docker run --rm -it \ -e ARM_CLIENT_SECRET \ -e ARM_SUBSCRIPTION_ID \ -e ARM_TENANT_ID \ - -e AAD_CLIENT_ID \ - -e AAD_CLIENT_SECRET \ -e KEY_ENCRYPTION_KEY_URL \ -e KEY_VAULT_RESOURCE_ID \ -v $(pwd):/data \ @@ -24,15 +22,15 @@ docker run --rm -it \ -var admin_password=$PASSWORD \ -var passphrase=$PASSWORD \ -var key_vault_name=$KEY_VAULT_NAME \ - -var aad_client_id=$AAD_CLIENT_ID \ - -var aad_client_secret=$AAD_CLIENT_SECRET \ + -var aad_client_id=$ARM_CLIENT_ID \ + -var aad_client_secret=$ARM_CLIENT_SECRET \ -var key_encryption_key_url=$KEY_ENCRYPTION_KEY_URL \ -var key_vault_resource_id=$KEY_VAULT_RESOURCE_ID; \ /bin/terraform apply out.tfplan" # cleanup deployed azure resources via azure-cli docker run --rm -it \ - azuresdk/azure-cli-python \ + azuresdk/azure-cli-python:0.2.10 \ sh -c "az login --service-principal -u $ARM_CLIENT_ID -p $ARM_CLIENT_SECRET --tenant $ARM_TENANT_ID > /dev/null; \ az vm show -g $KEY -n $KEY; \ az vm encryption show -g $KEY -n $KEY" @@ -43,6 +41,8 @@ docker run --rm -it \ -e ARM_CLIENT_SECRET \ -e ARM_SUBSCRIPTION_ID \ -e ARM_TENANT_ID \ + -e KEY_ENCRYPTION_KEY_URL \ + -e KEY_VAULT_RESOURCE_ID \ -v $(pwd):/data \ --workdir=/data \ --entrypoint "/bin/sh" \ @@ -54,7 +54,7 @@ docker run --rm -it \ -var admin_password=$PASSWORD \ -var passphrase=$PASSWORD \ -var key_vault_name=$KEY_VAULT_NAME \ - -var aad_client_id=$AAD_CLIENT_ID \ - -var aad_client_secret=$AAD_CLIENT_SECRET \ + -var aad_client_id=$ARM_CLIENT_ID \ + -var aad_client_secret=$ARM_CLIENT_SECRET \ -var key_encryption_key_url=$KEY_ENCRYPTION_KEY_URL \ -var key_vault_resource_id=$KEY_VAULT_RESOURCE_ID;" \ No newline at end of file diff --git a/examples/encrypt-running-linux-vm/main.tf b/examples/encrypt-running-linux-vm/main.tf index d87fa6efaa4e..fcd9736aa493 100644 --- a/examples/encrypt-running-linux-vm/main.tf +++ b/examples/encrypt-running-linux-vm/main.tf @@ -60,7 +60,7 @@ resource "azurerm_virtual_machine" "vm" { storage_os_disk { name = "${var.hostname}osdisk" create_option = "FromImage" - disk_size_gb = "15" + disk_size_gb = "30" } os_profile { diff --git a/examples/search-create/deploy.ci.sh b/examples/search-create/deploy.ci.sh index cbd6773bf95d..cda0f71e2cbe 100755 --- a/examples/search-create/deploy.ci.sh +++ b/examples/search-create/deploy.ci.sh @@ -19,7 +19,7 @@ docker run --rm -it \ # cleanup deployed azure resources via azure-cli docker run --rm -it \ - azuresdk/azure-cli-python \ + azuresdk/azure-cli-python:0.2.10 \ sh -c "az login --service-principal -u $ARM_CLIENT_ID -p $ARM_CLIENT_SECRET --tenant $ARM_TENANT_ID > /dev/null; \ az resource list --name $KEY" diff --git a/examples/spark-and-cassandra-on-centos/deploy.ci.sh b/examples/spark-and-cassandra-on-centos/deploy.ci.sh index ce4cd1fad323..3552cefc87f4 100755 --- a/examples/spark-and-cassandra-on-centos/deploy.ci.sh +++ b/examples/spark-and-cassandra-on-centos/deploy.ci.sh @@ -22,7 +22,7 @@ docker run --rm -it \ # cleanup deployed azure resources via azure-cli docker run --rm -it \ - azuresdk/azure-cli-python \ + azuresdk/azure-cli-python:0.2.10 \ sh -c "az login --service-principal -u $ARM_CLIENT_ID -p $ARM_CLIENT_SECRET --tenant $ARM_TENANT_ID > /dev/null; \ az vm list -g $KEY" diff --git a/examples/sql-database/deploy.ci.sh b/examples/sql-database/deploy.ci.sh index d1dc01df5a57..3a1d52bfe889 100755 --- a/examples/sql-database/deploy.ci.sh +++ b/examples/sql-database/deploy.ci.sh @@ -19,7 +19,7 @@ docker run --rm -it \ # check that resources exist via azure cli docker run --rm -it \ - azuresdk/azure-cli-python \ + azuresdk/azure-cli-python:0.2.10 \ sh -c "az login --service-principal -u $ARM_CLIENT_ID -p $ARM_CLIENT_SECRET --tenant $ARM_TENANT_ID > /dev/null; \ az sql db show -g $KEY -n MySQLDatabase -s $KEY-sqlsvr; \ az sql server show -g $KEY -n $KEY-sqlsvr;" diff --git a/examples/traffic-manager-vm/deploy.ci.sh b/examples/traffic-manager-vm/deploy.ci.sh index c9f291444666..016d3d66f228 100755 --- a/examples/traffic-manager-vm/deploy.ci.sh +++ b/examples/traffic-manager-vm/deploy.ci.sh @@ -19,7 +19,7 @@ docker run --rm -it \ # cleanup deployed azure resources via azure-cli docker run --rm -it \ - azuresdk/azure-cli-python \ + azuresdk/azure-cli-python:0.2.10 \ sh -c "az login --service-principal -u $ARM_CLIENT_ID -p $ARM_CLIENT_SECRET --tenant $ARM_TENANT_ID > /dev/null; \ az vm show -g $KEY -n rgvm" diff --git a/examples/vm-custom-image-new-storage-account/deploy.ci.sh b/examples/vm-custom-image-new-storage-account/deploy.ci.sh index d87f00abce2e..0ec389da23df 100755 --- a/examples/vm-custom-image-new-storage-account/deploy.ci.sh +++ b/examples/vm-custom-image-new-storage-account/deploy.ci.sh @@ -14,19 +14,19 @@ docker run --rm -it \ -c "/bin/terraform get; \ /bin/terraform validate; \ /bin/terraform plan -out=out.tfplan \ - -var source_img_uri=$EXISTING_IMAGE_URI \ + -var source_img_uri=$EXISTING_WINDOWS_IMAGE_URI \ -var hostname=$KEY \ -var resource_group=$KEY \ -var existing_resource_group=$EXISTING_RESOURCE_GROUP \ -var admin_password=$PASSWORD \ -var existing_storage_acct=$EXISTING_STORAGE_ACCOUNT_NAME \ - -var custom_image_name=$CUSTOM_IMAGE_NAME; \ + -var custom_image_name=$WINDOWS_DISK_NAME; \ /bin/terraform apply out.tfplan; \ /bin/terraform show;" # cleanup deployed azure resources via azure-cli docker run --rm -it \ - azuresdk/azure-cli-python \ + azuresdk/azure-cli-python:0.2.10 \ sh -c "az login --service-principal -u $ARM_CLIENT_ID -p $ARM_CLIENT_SECRET --tenant $ARM_TENANT_ID > /dev/null; \ az vm show -g $KEY -n myvm; \ az storage account show -g $KEY -n $KEY;" @@ -42,13 +42,13 @@ docker run --rm -it \ --entrypoint "/bin/sh" \ hashicorp/terraform:light \ -c "/bin/terraform destroy -force \ - -var source_img_uri=$EXISTING_IMAGE_URI \ + -var source_img_uri=$EXISTING_WINDOWS_IMAGE_URI \ -var hostname=$KEY \ -var resource_group=$KEY \ -var existing_resource_group=$EXISTING_RESOURCE_GROUP \ -var admin_password=$PASSWORD \ -var existing_storage_acct=$EXISTING_STORAGE_ACCOUNT_NAME \ - -var custom_image_name=$CUSTOM_IMAGE_NAME \ + -var custom_image_name=$WINDOWS_DISK_NAME \ -target=azurerm_virtual_machine.myvm \ -target=azurerm_virtual_machine.transfer \ -target=azurerm_network_interface.transfernic \ @@ -56,4 +56,10 @@ docker run --rm -it \ -target=azurerm_virtual_network.vnet \ -target=azurerm_public_ip.mypip \ -target=azurerm_public_ip.transferpip \ - -target=azurerm_storage_account.stor;" \ No newline at end of file + -target=azurerm_storage_account.stor;" + +# If you target the resource group to destroy with Terraform, it will destroy the existing storage account, so it must be deleted manually with the CLI. +docker run --rm -it \ + azuresdk/azure-cli-python:0.2.10 \ + sh -c "az login --service-principal -u $ARM_CLIENT_ID -p $ARM_CLIENT_SECRET --tenant $ARM_TENANT_ID > /dev/null; \ + az group delete -n $KEY -y" \ No newline at end of file diff --git a/examples/vm-custom-image-new-storage-account/deploy.mac.sh b/examples/vm-custom-image-new-storage-account/deploy.mac.sh index 3520afac693e..b26d068b1a81 100755 --- a/examples/vm-custom-image-new-storage-account/deploy.mac.sh +++ b/examples/vm-custom-image-new-storage-account/deploy.mac.sh @@ -8,9 +8,10 @@ if docker -v; then export KEY=$(cat /dev/urandom | env LC_CTYPE=C tr -cd 'a-z' | head -c 12) export PASSWORD=$KEY$(cat /dev/urandom | env LC_CTYPE=C tr -cd 'A-Z' | head -c 2)$(cat /dev/urandom | env LC_CTYPE=C tr -cd '0-9' | head -c 2) export EXISTING_RESOURCE_GROUP=donotdelete - export EXISTING_IMAGE_URI=https://donotdeletedisks636.blob.core.windows.net/vhds/mywindowsimage20170510184809.vhd + export EXISTING_WINDOWS_IMAGE_URI=https://tfpermstor.blob.core.windows.net/vhds/osdisk_alBZrO4OlX.vhd export EXISTING_STORAGE_ACCOUNT_NAME=donotdeletedisks636 - export CUSTOM_IMAGE_NAME=mywindowsimage20170510184809 + export CUSTOM_WINDOWS_IMAGE_NAME=WindowsImage + export WINDOWS_DISK_NAME=osdisk_alBZrO4OlX /bin/sh ./deploy.ci.sh diff --git a/examples/vm-custom-image-new-storage-account/variables.tf b/examples/vm-custom-image-new-storage-account/variables.tf index c0684f2c02f7..f6c329f72f39 100644 --- a/examples/vm-custom-image-new-storage-account/variables.tf +++ b/examples/vm-custom-image-new-storage-account/variables.tf @@ -22,7 +22,7 @@ variable "existing_storage_acct" { variable "existing_storage_acct_type" { description = "The type of the storage account in which your existing VHD and image reside" - default = "Premium_LRS" + default = "Standard_LRS" } variable "existing_resource_group" { diff --git a/examples/vm-from-user-image/deploy.ci.sh b/examples/vm-from-user-image/deploy.ci.sh index 37578ed7db12..a4efaee8191b 100755 --- a/examples/vm-from-user-image/deploy.ci.sh +++ b/examples/vm-from-user-image/deploy.ci.sh @@ -13,12 +13,12 @@ docker run --rm -it \ hashicorp/terraform:light \ -c "/bin/terraform get; \ /bin/terraform validate; \ - /bin/terraform plan -out=out.tfplan -var hostname=$KEY -var resource_group=$EXISTING_RESOURCE_GROUP -var admin_username=$KEY -var admin_password=$PASSWORD -var image_uri=$EXISTING_IMAGE_URI -var storage_account_name=$EXISTING_STORAGE_ACCOUNT_NAME; \ + /bin/terraform plan -out=out.tfplan -var hostname=$KEY -var resource_group=$EXISTING_RESOURCE_GROUP -var admin_username=$KEY -var admin_password=$PASSWORD -var image_uri=$EXISTING_LINUX_IMAGE_URI -var storage_account_name=$EXISTING_STORAGE_ACCOUNT_NAME; \ /bin/terraform apply out.tfplan; \ /bin/terraform show;" docker run --rm -it \ - azuresdk/azure-cli-python \ + azuresdk/azure-cli-python:0.2.10 \ sh -c "az login --service-principal -u $ARM_CLIENT_ID -p $ARM_CLIENT_SECRET --tenant $ARM_TENANT_ID > /dev/null; \ az vm show --name $KEY --resource-group permanent" @@ -37,9 +37,15 @@ docker run --rm -it \ -var resource_group=$EXISTING_RESOURCE_GROUP \ -var admin_username=$KEY \ -var admin_password=$PASSWORD \ - -var image_uri=$EXISTING_IMAGE_URI \ + -var image_uri=$EXISTING_LINUX_IMAGE_URI \ -var storage_account_name=$EXISTING_STORAGE_ACCOUNT_NAME \ -target=azurerm_virtual_machine.vm \ -target=azurerm_network_interface.nic \ -target=azurerm_virtual_network.vnet \ -target=azurerm_public_ip.pip;" + +# The os disks must be deleted manually from the permanent resource group as this group is not under Terraform's state. +docker run --rm -it \ + azuresdk/azure-cli-python:0.2.10 \ + sh -c "az login --service-principal -u $ARM_CLIENT_ID -p $ARM_CLIENT_SECRET --tenant $ARM_TENANT_ID > /dev/null; \ + az disk delete --name $KEY-osdisk --resource-group permanent -y" \ No newline at end of file diff --git a/examples/vm-from-user-image/deploy.mac.sh b/examples/vm-from-user-image/deploy.mac.sh index 5073b40358f2..35b1ef6a99c4 100755 --- a/examples/vm-from-user-image/deploy.mac.sh +++ b/examples/vm-from-user-image/deploy.mac.sh @@ -7,8 +7,8 @@ if docker -v; then # generate a unique string for CI deployment export KEY=$(cat /dev/urandom | env LC_CTYPE=C tr -cd 'a-z' | head -c 12) export PASSWORD=$KEY$(cat /dev/urandom | env LC_CTYPE=C tr -cd 'A-Z' | head -c 2)$(cat /dev/urandom | env LC_CTYPE=C tr -cd '0-9' | head -c 2) - export EXISTING_IMAGE_URI=https://permanentstor.blob.core.windows.net/permanent-vhds/permanent-osdisk1.vhd - export EXISTING_STORAGE_ACCOUNT_NAME=permanentstor + export EXISTING_LINUX_IMAGE_URI=https://tfpermstor.blob.core.windows.net/vhds/osdisk_fmF5O5MxlR.vhd + export EXISTING_STORAGE_ACCOUNT_NAME=tfpermstor export EXISTING_RESOURCE_GROUP=permanent /bin/sh ./deploy.ci.sh diff --git a/examples/vm-from-user-image/main.tf b/examples/vm-from-user-image/main.tf index 8444377f848f..1295afb2ba16 100644 --- a/examples/vm-from-user-image/main.tf +++ b/examples/vm-from-user-image/main.tf @@ -55,7 +55,7 @@ resource "azurerm_virtual_machine" "vm" { storage_os_disk { name = "${var.hostname}-osdisk1" image_uri = "${var.image_uri}" - vhd_uri = "https://${var.storage_account_name}.blob.core.windows.net/vhds/${var.hostname}osdisk.vhd" + vhd_uri = "https://${var.storage_account_name}.blob.core.windows.net/vhds/${var.hostname}-osdisk.vhd" os_type = "${var.os_type}" caching = "ReadWrite" create_option = "FromImage" diff --git a/examples/vm-simple-linux-managed-disk/deploy.ci.sh b/examples/vm-simple-linux-managed-disk/deploy.ci.sh index 71e407526186..46e3c947cf75 100755 --- a/examples/vm-simple-linux-managed-disk/deploy.ci.sh +++ b/examples/vm-simple-linux-managed-disk/deploy.ci.sh @@ -19,7 +19,7 @@ docker run --rm -it \ # cleanup deployed azure resources via azure-cli docker run --rm -it \ - azuresdk/azure-cli-python \ + azuresdk/azure-cli-python:0.2.10 \ sh -c "az login --service-principal -u $ARM_CLIENT_ID -p $ARM_CLIENT_SECRET --tenant $ARM_TENANT_ID > /dev/null; \ az vm show -g $KEY -n rgvm" diff --git a/examples/vm-specialized-vhd-existing-vnet/deploy.ci.sh b/examples/vm-specialized-vhd-existing-vnet/deploy.ci.sh index 3ffdcaa21608..502a0a288503 100755 --- a/examples/vm-specialized-vhd-existing-vnet/deploy.ci.sh +++ b/examples/vm-specialized-vhd-existing-vnet/deploy.ci.sh @@ -14,7 +14,7 @@ docker run --rm -it \ -c "/bin/terraform get; \ /bin/terraform validate; \ /bin/terraform plan -out=out.tfplan \ - -var os_disk_vhd_uri=$EXISTING_IMAGE_URI \ + -var os_disk_vhd_uri=$EXISTING_LINUX_IMAGE_URI \ -var hostname=$KEY \ -var resource_group=$KEY \ -var existing_vnet_resource_group=$EXISTING_RESOURCE_GROUP \ @@ -28,7 +28,7 @@ docker run --rm -it \ # cleanup deployed azure resources via azure-cli docker run --rm -it \ - azuresdk/azure-cli-python \ + azuresdk/azure-cli-python:0.2.10 \ sh -c "az login --service-principal -u $ARM_CLIENT_ID -p $ARM_CLIENT_SECRET --tenant $ARM_TENANT_ID > /dev/null; \ az vm show -g $KEY -n $KEY" @@ -43,12 +43,12 @@ docker run --rm -it \ --entrypoint "/bin/sh" \ hashicorp/terraform:light \ -c "/bin/terraform destroy -force \ - -var os_disk_vhd_uri=$EXISTING_IMAGE_URI \ + -var os_disk_vhd_uri=$EXISTING_LINUX_IMAGE_URI \ -var hostname=$KEY \ -var resource_group=$KEY \ -var existing_vnet_resource_group=$EXISTING_RESOURCE_GROUP \ -var admin_password=$PASSWORD \ - -var existing_subnet_id=$EXISTING_SUBNET_ID \ + -var existing_subnet_id=/subscriptions/$ARM_SUBSCRIPTION_ID/resourceGroups/permanent/providers/Microsoft.Network/virtualNetworks/$EXISTING_VIRTUAL_NETWORK_NAME/subnets/$EXISTING_SUBNET_NAME \ -var existing_subnet_name=$EXISTING_SUBNET_NAME \ -var existing_virtual_network_name=$EXISTING_VIRTUAL_NETWORK_NAME \ -var existing_storage_acct=$EXISTING_STORAGE_ACCOUNT_NAME \ diff --git a/examples/vm-specialized-vhd-existing-vnet/deploy.mac.sh b/examples/vm-specialized-vhd-existing-vnet/deploy.mac.sh index 6f555e7a6bdb..a0ecce7dc33e 100755 --- a/examples/vm-specialized-vhd-existing-vnet/deploy.mac.sh +++ b/examples/vm-specialized-vhd-existing-vnet/deploy.mac.sh @@ -8,10 +8,10 @@ if docker -v; then export KEY=$(cat /dev/urandom | env LC_CTYPE=C tr -cd 'a-z' | head -c 12) export PASSWORD=$KEY$(cat /dev/urandom | env LC_CTYPE=C tr -cd 'A-Z' | head -c 2)$(cat /dev/urandom | env LC_CTYPE=C tr -cd '0-9' | head -c 2) export EXISTING_RESOURCE_GROUP=permanent - export EXISTING_IMAGE_URI=https://permanentstor.blob.core.windows.net/permanent-vhds/permanent-osdisk1.vhd - export EXISTING_STORAGE_ACCOUNT_NAME=permanentstor - export EXISTING_VIRTUAL_NETWORK_NAME=vqeeopeictwmvnet - export EXISTING_SUBNET_NAME=vqeeopeictwmsubnet + export EXISTING_LINUX_IMAGE_URI=https://tfpermstor.blob.core.windows.net/vhds/osdisk_fmF5O5MxlR.vhd + export EXISTING_STORAGE_ACCOUNT_NAME=tfpermstor + export EXISTING_VIRTUAL_NETWORK_NAME=permanent-vnet + export EXISTING_SUBNET_NAME=permanent-subnet /bin/sh ./deploy.ci.sh diff --git a/examples/vnet-to-vnet-peering/deploy.ci.sh b/examples/vnet-to-vnet-peering/deploy.ci.sh index 4b7c1d693385..add76e4aef40 100755 --- a/examples/vnet-to-vnet-peering/deploy.ci.sh +++ b/examples/vnet-to-vnet-peering/deploy.ci.sh @@ -19,7 +19,7 @@ docker run --rm -it \ # cleanup deployed azure resources via azure-cli docker run --rm -it \ - azuresdk/azure-cli-python \ + azuresdk/azure-cli-python:0.2.10 \ sh -c "az login --service-principal -u $ARM_CLIENT_ID -p $ARM_CLIENT_SECRET --tenant $ARM_TENANT_ID > /dev/null; \ az network vnet peering show -g $KEY --vnet-name $KEY'-vnet1' -n vNet1-to-vNet2; az network vnet peering show -g $KEY --vnet-name $KEY'-vnet2' -n vNet2-to-vNet1;" diff --git a/examples/vnet-two-subnets/deploy.ci.sh b/examples/vnet-two-subnets/deploy.ci.sh index 49fb955c7eab..0e895f408910 100755 --- a/examples/vnet-two-subnets/deploy.ci.sh +++ b/examples/vnet-two-subnets/deploy.ci.sh @@ -23,7 +23,7 @@ docker run --rm -it \ # check that resources exist via azure cli docker run --rm -it \ - azuresdk/azure-cli-python \ + azuresdk/azure-cli-python:0.2.10 \ sh -c "az login --service-principal -u $ARM_CLIENT_ID -p $ARM_CLIENT_SECRET --tenant $ARM_TENANT_ID > /dev/null; \ az network vnet subnet show -n subnet1 -g $KEY --vnet-name '$KEY'vnet; \ az network vnet subnet show -n subnet2 -g $KEY --vnet-name '$KEY'vnet;"