Microsoft Azureの近接通信配置グループ(Manage Proximity Placement Groups)の使い方を説明します。近接通信配置グループは、物理的に近い位置に仮想マシンを配置する設定で低レイテンシを求められるアプリケーションに対して使用します。同一の可用性ゾーンに配置すれば低レイテンシを実現する事もできますが、近接通信配置グループは同一の可用性ゾーンよりも小さいレイテンシを実現する事ができます。
参考資料
参考になる公式ドキュメントを以下に示します。
事前準備
以下、仮想ネットワーク等のリソースを作成します。
az group create --name MyResourceGroup --location japaneast
az network vnet create \
-g MyResourceGroup \
-n MyVnet \
--address-prefix 172.16.0.0/16 \
--subnet-name MySubnet \
--subnet-prefix 172.16.0.0/24
近接通信配置グループの作成
近接通信配置グループを定義します。
az ppg create \ --resource-group MyResourceGroup \ --location japaneast \ --name MyPpg
仮想マシンの作成
Azure CLI
近接通信配置グループ内に仮想マシンを作成します。必須オプションではないですが、一般的な業務要件を想定すると、仮想マシンを作成する時は高速ネットワークを有効にするのが望ましいです。
近接通信配置グループは低レイテンシを目指すので、高速ネットワークを使用しないのは本末転倒です。高速ネットワークだけで要件を満たさない場合に近接通信配置グループを使用するようにしましょう。
高速ネットワーク(accelerated-networking)は、廉価なBシリーズの仮想マシンはサポートされません。
for VM_NAME in linux010 linux011
do
az vm create \
--resource-group MyResourceGroup \
--name ${VM_NAME} \
--ppg MyPpg \
--accelerated-networking true \
--image UbuntuLTS \
--size Standard_D1_v2 \
--admin-username azureuser \
--authentication-type ssh \
--ssh-key-values ~/.ssh/authorized_keys
done
az ppg showコマンドに引数include-colocation-statusを与えると、近接通信配置グループに配置されているかどうかを確認できます。
$ az ppg show \
--resource-group MyResourceGroup \
--name MyPpg \
--include-colocation-status
{
"availabilitySets": [],
"colocationStatus": {
"code": "ColocationStatus/Aligned",
"displayStatus": "Aligned",
"level": "Info",
"message": "All resources in the proximity placement group are aligned.",
"time": null
},
"id": "/subscriptions/2e2f81a9-b030-410f-9784-c582580c932e/resourceGroups/MyResourceGroup/providers/Microsoft.Compute/proximityPlacementGroups/MyPpg",
"location": "japaneast",
"name": "MyPpg",
"proximityPlacementGroupType": "Standard",
"resourceGroup": "MyResourceGroup",
"tags": {},
"type": "Microsoft.Compute/proximityPlacementGroups",
"virtualMachineScaleSets": [],
"virtualMachines": [
{
"colocationStatus": null,
"id": "/subscriptions/2e2f81a9-b030-410f-9784-c582580c932e/resourceGroups/MYRESOURCEGROUP/providers/Microsoft.Compute/virtualMachines/LINUX010",
"resourceGroup": "MYRESOURCEGROUP"
},
{
"colocationStatus": null,
"id": "/subscriptions/2e2f81a9-b030-410f-9784-c582580c932e/resourceGroups/MYRESOURCEGROUP/providers/Microsoft.Compute/virtualMachines/LINUX011",
"resourceGroup": "MYRESOURCEGROUP"
}
]
}
ポータルで確認する場合は以下のようになります。

ARM template
azコマンドでは同時に仮想マシンをデプロイする事はできないません。ですので、1つ目にデプロイした仮想マシンと同一の物理配置に、2つ目の仮想マシンをデプロイできない可能性もあります。このような場合はOverconstrainedAllocationRequestエラーが返されます。
この現象を回避するには、単一のARM templateでデプロイします。以下に極力最小限のパラメタにしたARM templateの設定例を示します。この設定例をtemplate.jsonという名前で保存します。
{
"$schema": "http://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"proximityPlacementName": {
"type": "string",
"defaultValue": "MyPpg"
},
"machinePrefixName": {
"type": "string",
"defaultValue": "linux02"
},
"numberOfMachine": {
"type": "int",
"defaultValue": 2
}
},
"variables": {
"location": "japaneast",
"vnetName": "MyVnet",
"subnetName": "MySubnet"
},
"resources": [
{
"name": "[concat(parameters('machinePrefixName'), copyIndex(), 'VMNic')]",
"type": "Microsoft.Network/networkInterfaces",
"apiVersion": "2021-03-01",
"location": "[variables('location')]",
"properties": {
"enableAcceleratedNetworking" : true,
"ipConfigurations": [
{
"name": "ipconfig1",
"properties": {
"privateIpAddressVersion": "IPv4",
"privateIPAllocationMethod": "Dynamic",
"subnet": {
"id": "[resourceId('Microsoft.Network/virtualNetworks/subnets', variables('vnetName'), variables('subnetName'))]"
}
}
}
]
},
"copy": {
"name": "CopyNic",
"count": "[parameters('numberOfMachine')]"
}
},
{
"name": "[concat(parameters('machinePrefixName'), copyIndex())]",
"type": "Microsoft.Compute/virtualMachines",
"apiVersion": "2021-11-01",
"location": "[variables('location')]",
"dependsOn": [
"[resourceId('Microsoft.Network/networkInterfaces', concat(parameters('machinePrefixName'), copyIndex(), 'VMNic'))]"
],
"properties": {
"hardwareProfile": {
"vmSize": "Standard_D1_v2"
},
"storageProfile": {
"imageReference": {
"publisher": "Canonical",
"offer": "UbuntuServer",
"sku": "18.04-LTS",
"version": "latest"
}
},
"osProfile": {
"computerName": "[concat(parameters('machinePrefixName'), copyIndex())]",
"adminUsername": "azureuser",
"adminPassword": "P@ssw0rd1234"
},
"networkProfile": {
"networkInterfaces": [
{
"id": "[resourceId('Microsoft.Network/networkInterfaces', concat(parameters('machinePrefixName'), copyIndex(), 'VMNic'))]"
}
]
},
"proximityPlacementGroup": {
"id": "[resourceId('Microsoft.Compute/proximityPlacementGroups', parameters('proximityPlacementName'))]"
}
},
"copy": {
"name": "CopyVm",
"count": "[parameters('numberOfMachine')]"
}
}
]
}
想定通りの仮想マシンが近接通信配置グループに配置された事を確認します。
$ az ppg show \
--resource-group MyResourceGroup \
--name MyPpg \
--include-colocation-status
{
"availabilitySets": [],
"colocationStatus": {
"code": "ColocationStatus/Aligned",
"displayStatus": "Aligned",
"level": "Info",
"message": "All resources in the proximity placement group are aligned.",
"time": null
},
"id": "/subscriptions/2e2f81a9-b030-410f-9784-c582580c932e/resourceGroups/MyResourceGroup/providers/Microsoft.Compute/proximityPlacementGroups/MyPpg",
"location": "japaneast",
"name": "MyPpg",
"proximityPlacementGroupType": "Standard",
"resourceGroup": "MyResourceGroup",
"tags": {},
"type": "Microsoft.Compute/proximityPlacementGroups",
"virtualMachineScaleSets": [],
"virtualMachines": [
{
"colocationStatus": null,
"id": "/subscriptions/2e2f81a9-b030-410f-9784-c582580c932e/resourceGroups/MYRESOURCEGROUP/providers/Microsoft.Compute/virtualMachines/LINUX010",
"resourceGroup": "MYRESOURCEGROUP"
},
{
"colocationStatus": null,
"id": "/subscriptions/2e2f81a9-b030-410f-9784-c582580c932e/resourceGroups/MYRESOURCEGROUP/providers/Microsoft.Compute/virtualMachines/LINUX011",
"resourceGroup": "MYRESOURCEGROUP"
},
{
"colocationStatus": null,
"id": "/subscriptions/2e2f81a9-b030-410f-9784-c582580c932e/resourceGroups/MYRESOURCEGROUP/providers/Microsoft.Compute/virtualMachines/LINUX020",
"resourceGroup": "MYRESOURCEGROUP"
},
{
"colocationStatus": null,
"id": "/subscriptions/2e2f81a9-b030-410f-9784-c582580c932e/resourceGroups/MYRESOURCEGROUP/providers/Microsoft.Compute/virtualMachines/LINUX021",
"resourceGroup": "MYRESOURCEGROUP"
}
]
}
ARM templateを使って仮想マシンをデプロイします。
az deployment group create \ --name deploy_vm \ --resource-group MyResourceGroup \ --template-file template.json
ポータルで確認する場合は以下のようになります。

