背景と目的
VNET 間で相互通信する場合、VNET ピアリングを設定すれば、相互に IP アドレスで通信を行う事ができます。IP アドレスは台数が少ないうちは覚えられるので問題になりませんが、台数が増えてくると覚えられなくなり、凡ミスを誘発しやすくなります。また、IP アドレスのまま運用していると、例えば仮想マシンに不具合が生じて新しい仮想マシンを用意して入れ替えたい場合、その仮想マシンに通信している通信元の台数分の設定変更が必要ですが、名前解決なら TTL を短くしておき A レコードを書き換えるだけで済みます。そこで、ミスを減らしたりメンテナンスを楽にするため、名前解決できるようにして人間でも覚えやすい命名規則で運用します。VNET とオンプレがつながっているならオンプレ側に DNS があり、それを利用するのも可能ですが、オススメはオンプレとのネットワークが切れてしまっても影響されないよう、Azure 側に プライベート DNS ゾーンを用意する方法です。ということで今回は、下記構成図のような 1 つの Azure プライベート DNS ゾーンを 2 つの VNET から使う構成を Azure CLI で作ってみました。
検証用 VNET を作成
bash
# 環境変数をセットします
region=japaneast
prefix=mnrpdns
# リソースグループを作成します
az group create \
--name ${prefix}-rg \
--location $region
# VNET を 2 つ作成します
for i in {1..2}; do
az network vnet create \
--name ${prefix}-vnet${i} \
--resource-group ${prefix}-rg \
--address-prefix 172.16.${i}.0/24
done
# NSG を 2 つ作成します
for i in {1..2}; do
az network nsg create \
--resource-group ${prefix}-rg \
--name ${prefix}-nsg${i}
done
# それぞれの VNET にサブネットを作成します
for i in {1..2}; do
az network vnet subnet create \
--vnet-name ${prefix}-vnet${i} \
--resource-group ${prefix}-rg \
--name vm-subnet \
--address-prefix 172.16.${i}.0/28 \
--network-security-group ${prefix}-nsg${i}
done
VNET ピアリングを作成
bash
# vnet1 から vnet2 へのピアリングを作成します
az network vnet peering create \
--name vnet1-vnet2 \
--resource-group ${prefix}-rg \
--vnet-name ${prefix}-vnet1 \
--remote-vnet ${prefix}-vnet2 \
--allow-vnet-access
# vnet2 から vnet1 へのピアリングを作成します
az network vnet peering create \
--name vnet2-vnet1 \
--resource-group ${prefix}-rg \
--vnet-name ${prefix}-vnet2 \
--remote-vnet ${prefix}-vnet1 \
--allow-vnet-access
プライベート DNS ゾーンを作成
bash
# 1 つのプライベート DNS ゾーンを作成します
az network private-dns zone create \
--resource-group ${prefix}-rg \
--name ${prefix}.local
# それぞれの VNET とプライベート DNS ゾーンを紐づけます
for i in {1..2}; do
az network private-dns link vnet create \
--resource-group ${prefix}-rg \
--name ${prefix}-pdns${i} \
--zone-name ${prefix}.local \
--virtual-network ${prefix}-vnet${i} \
--registration-enabled true
done
仮想マシンを作成
bash
# それぞれの VNET にパブリック IP アドレスなしの仮想マシンを作成します
for i in {1..2}; do
az vm create \
--resource-group ${prefix}-rg \
--name ${prefix}-vm${i} \
--os-disk-name ${prefix}-vm${i}OSDisk \
--image CentOS \
--size Standard_B1s \
--admin-username azureuser \
--generate-ssh-keys \
--vnet-name ${prefix}-vnet${i} \
--subnet vm-subnet \
--nsg "" \
--public-ip-address "" \
--storage-sku Standard_LRS
done
プライベート DNS ゾーンに登録された情報を確認
bash
# DNS レコードのリストを表示します
az network private-dns record-set list \
--resource-group ${prefix}-rg \
--zone-name ${prefix}.local \
--output table
# 表示結果を見ると 2 つの仮想マシンの A レコードが自動登録されていることが確認できます
Name ResourceGroup Ttl Type AutoRegistered Metadata
----------- --------------- ----- ------ ---------------- ----------
@ mnrpdns-rg 3600 SOA False
mnrpdns-vm1 mnrpdns-rg 10 A True
mnrpdns-vm2 mnrpdns-rg 10 A True
それぞれの仮想マシンから名前解決と相互通信を確認
bash
# 名前解決を確認します
for i in {1..2}; do
az vm run-command invoke \
--resource-group ${prefix}-rg \
--name ${prefix}-vm${i} \
--command-id RunShellScript \
--scripts "host ${prefix}-vm1.${prefix}.local; host ${prefix}-vm2.${prefix}.local" \
--query value[].message \
--output tsv
done
# vm1 側の出力結果
Enable succeeded:
[stdout]
mnrpdns-vm1.mnrpdns.local has address 172.16.1.4
mnrpdns-vm2.mnrpdns.local has address 172.16.2.4
[stderr]
# vm2 側の出力結果
Enable succeeded:
[stdout]
mnrpdns-vm1.mnrpdns.local has address 172.16.1.4
mnrpdns-vm2.mnrpdns.local has address 172.16.2.4
[stderr]
# 相互通信を確認します
for i in {1..2}; do
az vm run-command invoke \
--resource-group ${prefix}-rg \
--name ${prefix}-vm${i} \
--command-id RunShellScript \
--scripts "ping -c 4 ${prefix}-vm1.${prefix}.local; ping -c 4 ${prefix}-vm2.${prefix}.local" \
--query value[].message \
--output tsv
done
# vm1 側の出力結果
Enable succeeded:
[stdout]
PING mnrpdns-vm1.mnrpdns.local (172.16.1.4) 56(84) bytes of data.
64 bytes from mnrpdns-vm1.internal.cloudapp.net (172.16.1.4): icmp_seq=1 ttl=64 time=0.020 ms
64 bytes from mnrpdns-vm1.internal.cloudapp.net (172.16.1.4): icmp_seq=2 ttl=64 time=0.049 ms
64 bytes from mnrpdns-vm1.internal.cloudapp.net (172.16.1.4): icmp_seq=3 ttl=64 time=0.042 ms
64 bytes from mnrpdns-vm1.internal.cloudapp.net (172.16.1.4): icmp_seq=4 ttl=64 time=0.048 ms
--- mnrpdns-vm1.mnrpdns.local ping statistics ---
4 packets transmitted, 4 received, 0% packet loss, time 3001ms
rtt min/avg/max/mdev = 0.020/0.039/0.049/0.014 ms
PING mnrpdns-vm2.mnrpdns.local (172.16.2.4) 56(84) bytes of data.
64 bytes from 172.16.2.4 (172.16.2.4): icmp_seq=1 ttl=64 time=3.68 ms
64 bytes from 172.16.2.4 (172.16.2.4): icmp_seq=2 ttl=64 time=1.11 ms
64 bytes from 172.16.2.4 (172.16.2.4): icmp_seq=3 ttl=64 time=1.14 ms
64 bytes from 172.16.2.4 (172.16.2.4): icmp_seq=4 ttl=64 time=1.37 ms
--- mnrpdns-vm2.mnrpdns.local ping statistics ---
4 packets transmitted, 4 received, 0% packet loss, time 3004ms
rtt min/avg/max/mdev = 1.112/1.829/3.682/1.075 ms
[stderr]
# vm2 側の出力結果
Enable succeeded:
[stdout]
PING mnrpdns-vm1.mnrpdns.local (172.16.1.4) 56(84) bytes of data.
64 bytes from 172.16.1.4 (172.16.1.4): icmp_seq=1 ttl=64 time=0.951 ms
64 bytes from 172.16.1.4 (172.16.1.4): icmp_seq=2 ttl=64 time=4.15 ms
64 bytes from 172.16.1.4 (172.16.1.4): icmp_seq=3 ttl=64 time=1.28 ms
64 bytes from 172.16.1.4 (172.16.1.4): icmp_seq=4 ttl=64 time=1.51 ms
--- mnrpdns-vm1.mnrpdns.local ping statistics ---
4 packets transmitted, 4 received, 0% packet loss, time 3003ms
rtt min/avg/max/mdev = 0.951/1.975/4.159/1.277 ms
PING mnrpdns-vm2.mnrpdns.local (172.16.2.4) 56(84) bytes of data.
64 bytes from mnrpdns-vm2.internal.cloudapp.net (172.16.2.4): icmp_seq=1 ttl=64 time=0.024 ms
64 bytes from mnrpdns-vm2.internal.cloudapp.net (172.16.2.4): icmp_seq=2 ttl=64 time=0.063 ms
64 bytes from mnrpdns-vm2.internal.cloudapp.net (172.16.2.4): icmp_seq=3 ttl=64 time=0.054 ms
64 bytes from mnrpdns-vm2.internal.cloudapp.net (172.16.2.4): icmp_seq=4 ttl=64 time=0.056 ms
--- mnrpdns-vm2.mnrpdns.local ping statistics ---
4 packets transmitted, 4 received, 0% packet loss, time 3001ms
rtt min/avg/max/mdev = 0.024/0.049/0.063/0.015 ms
[stderr]
検証環境を削除
bash
# リソースグループを削除します
az group delete \
--name ${prefix}-rg \
--yes
参考