-
Notifications
You must be signed in to change notification settings - Fork 34
/
Copy pathhubandspoke_simple.azcli
74 lines (68 loc) · 4.81 KB
/
hubandspoke_simple.azcli
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
# Create a simple hub and spoke environment
# Used for FTA Live sessions
# Variables
rg=ftalive
location=westeurope
hub_vnet_name=hubvnet
hub_vnet_prefix=10.1.0.0/24
hub_subnet_name=vm
hub_subnet_prefix=10.1.0.0/26
spoke_vnet_name=spokevnet
spoke_vnet_prefix=10.1.1.0/24
spoke_subnet_name=vm
spoke_subnet_prefix=10.1.1.0/26
vm_size=Standard_B1s
hub_vm_name=hubvm
spoke_vm_name=spokevm
spoke_rt_name=spokert
# Create environment
echo "Creating RG and VNets..."
az group create -n $rg -l $location -o none
az network vnet create -g $rg -n $hub_vnet_name --address-prefix $hub_vnet_prefix --subnet-name $hub_subnet_name --subnet-prefix $hub_subnet_prefix -l $location -o none
az network vnet create -g $rg -n $spoke_vnet_name --address-prefix $spoke_vnet_prefix --subnet-name $spoke_subnet_name --subnet-prefix $spoke_subnet_prefix -l $location -o none
echo "Creating Virtual machines..."
az vm create -n $hub_vm_name -g $rg -l $location --image ubuntuLTS --generate-ssh-keys -o none --public-ip-sku Standard \
--public-ip-address "${hub_vm_name}-pip" --vnet-name $hub_vnet_name --size $vm_size --subnet $hub_subnet_name -l $location --no-wait
az vm create -n $spoke_vm_name -g $rg -l $location --image ubuntuLTS --generate-ssh-keys -o none --public-ip-sku Standard \
--public-ip-address "${spoke_vm_name}-pip" --vnet-name $spoke_vnet_name --size $vm_size --subnet $spoke_subnet_name -l $location --no-wait
echo "Peering VNets..."
az network vnet peering create -n hub2spoke -g $rg --vnet-name $hub_vnet_name --remote-vnet $spoke_vnet_name --allow-vnet-access --allow-forwarded-traffic -o none
az network vnet peering create -n spoke2hub -g $rg --vnet-name $spoke_vnet_name --remote-vnet $hub_vnet_name --allow-vnet-access --allow-forwarded-traffic -o none
echo "Configuring VMs..."
hub_nic_id=$(az vm show -n $hub_vm_name -g $rg --query 'networkProfile.networkInterfaces[0].id' -o tsv)
az network nic update --ids $hub_nic_id --ip-forwarding -o none
hub_private_ip=$(az network nic show --ids $hub_nic_id --query 'ipConfigurations[0].privateIpAddress' -o tsv)
az network route-table create -n $spoke_rt_name -g $rg -l $location -o none
az network route-table route create --route-table-name $spoke_rt_name -g $rg --address-prefix '0.0.0.0/0' -n default --next-hop-type VirtualAppliance --next-hop-ip-address $hub_private_ip -o none
myip=$(curl -s4 ifconfig.co)
az network route-table route create -n mypc -g $rg --route-table-name $spoke_rt_name --address-prefix "${myip}/32" --next-hop-type Internet -o none
az network vnet subnet update -g $rg --vnet-name $spoke_vnet_name -n $spoke_subnet_name --route-table $spoke_rt_name -o none
hub_pip=$(az network public-ip show -n "${hub_vm_name}-pip" -g $rg --query 'ipAddress' -o tsv)
ssh -n -o BatchMode=yes -o StrictHostKeyChecking=no $hub_pip "sudo sysctl -w net.ipv4.ip_forward=1"
ssh -n -o BatchMode=yes -o StrictHostKeyChecking=no $hub_pip "sudo iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE"
# Update route table with new IP (might be necessary if the local PIP changed)
myip=$(curl -s4 ifconfig.co)
az network route-table route update -n mypc -g $rg --route-table-name $spoke_rt_name --address-prefix "${myip}/32" --next-hop-type Internet -o none
# Update hub VM NSG
hub_nsg_id=$(az network nic show --ids $hub_nic_id --query 'networkSecurityGroup.id' -o tsv)
hub_nsg_name=$(echo $hub_nsg_id | cut -d/ -f 9)
az network nsg rule create --nsg-name $hub_nsg_name -g $rg -n Allow_Inbound_From_RFC1918 --priority 1010 \
--access Allow --protocol '*' --source-address-prefixes '10.0.0.0/8' '172.16.0.0/12' '192.168.0.0/16' --direction Inbound \
--destination-address-prefixes '*' --destination-port-ranges '*' -o none
# Diagnostics
hub_nic_id=$(az vm show -n $hub_vm_name -g $rg --query 'networkProfile.networkInterfaces[0].id' -o tsv)
spoke_nic_id=$(az vm show -n $spoke_vm_name -g $rg --query 'networkProfile.networkInterfaces[0].id' -o tsv)
hub_pip=$(az network public-ip show -n "${hub_vm_name}-pip" -g $rg --query 'ipAddress' -o tsv)
spoke_pip=$(az network public-ip show -n "${spoke_vm_name}-pip" -g $rg --query 'ipAddress' -o tsv)
az vm list-ip-addresses -o table -g $rg
az network route-table list -g $rg -o table
az network route-table route list --route-table-name $spoke_rt_name -g $rg -o table
az network nic show-effective-route-table --ids $hub_nic_id -o table
az network nic show-effective-route-table --ids $spoke_nic_id -o table
ssh -n -o BatchMode=yes -o StrictHostKeyChecking=no $hub_pip "curl -s4 ifconfig.co"
ssh -n -o BatchMode=yes -o StrictHostKeyChecking=no $hub_pip "sysctl net.ipv4.ip_forward"
ssh -n -o BatchMode=yes -o StrictHostKeyChecking=no $hub_pip "sudo iptables -L -t nat"
ssh -n -o BatchMode=yes -o StrictHostKeyChecking=no $spoke_pip "curl -s4 ifconfig.co"
az network vnet subnet show -n $spoke_subnet_name -g $rg --vnet-name $spoke_vnet_name --query routeTable -o tsv
# Cleanup
# az group delete -y -n $rg --no-wait