如何在 Azure 中使用 ARM 模板或 Ambari API 获取边缘节点的私有 IP

How to get a Private IP of Edge node using ARM template or Ambari API in Azure

如何使用 ARM 模板和 Ambari 获取边缘节点的私有 IP API?

我正在使用 ARM 模板的以下 edgenode 部分安装 Edge 节点。我想为我的自定义应用程序获取私有 IP 边缘节点。如何使用 ARM 模板或通过使用 edgenodeName 使用 Ambari 获取它?

{
  'name': '[concat(parameters('clusterName'),'/', parameters('edgenodeName'))]',
  'type': 'Microsoft.HDInsight/clusters/applications',
  'apiVersion': '2015-03-01-preview',
    'dependsOn': [
        '[concat('Microsoft.HDInsight/clusters/', parameters('clusterName'))]'
    ],
    'properties': {
    'marketPlaceIdentifier': 'EmptyEdgeNode',
    'computeProfile': {
      'roles': [{
        'name': 'edgenode',
        'targetInstanceCount': 1,
        'hardwareProfile': {
          'vmSize': '[parameters('edgenodeSize')]'
        }
      }]
    },
    'installScriptActions': [],
    'uninstallScriptActions': [],
    'httpsEndpoints': [],
    'applicationType': 'CustomApplication'
  }
}

更新一:-

这是我的 json 来自 resources.azure.com

的代表
{
  "id": "/subscriptions/$subscriptionId/resourceGroups/$resourceGroupName/providers/Microsoft.HDInsight/clusters/$clusterName",
  "name": "$clusterName",
  "type": "Microsoft.HDInsight/clusters",
  "location": "Central US",
  "etag": "33908087-88d4-43e6-bad4-7668bb90fa39",
  "tags": null,
  "properties": {
    "clusterVersion": "3.5.1000.0",
    "osType": "Linux",
    "clusterDefinition": {
      "blueprint": "https://blueprints.azurehdinsight.net/spark-3.5.1000.0.9988582.json",
      "kind": "SPARK",
      "componentVersion": {
        "Spark": "1.6"
      }
    },
    "computeProfile": {
      "roles": [
        {
          "name": "headnode",
          "targetInstanceCount": 2,
          "hardwareProfile": {
            "vmSize": "Standard_D12_V2"
          },
          "osProfile": {
            "linuxOperatingSystemProfile": {
              "username": "$userName"
            }
          },
          "virtualNetworkProfile": {
            "id": "/subscriptions/$subscriptionId/resourceGroups/$resourceGroupName/providers/Microsoft.Network/virtualNetworks/$vnetName",
            "subnet": "/subscriptions/$subscriptionId/resourceGroups/$resourceGroupName/providers/Microsoft.Network/virtualNetworks/$vnetName/subnets/default"
          }
        },
        {
          "name": "workernode",
          "targetInstanceCount": 1,
          "hardwareProfile": {
            "vmSize": "Standard_D12_V2"
          },
          "osProfile": {
            "linuxOperatingSystemProfile": {
              "username": "$userName"
            }
          },
          "virtualNetworkProfile": {
            "id": "/subscriptions/$subscriptionId/resourceGroups/$resourceGroupName/providers/Microsoft.Network/virtualNetworks/$vnetName",
            "subnet": "/subscriptions/$subscriptionId/resourceGroups/$resourceGroupName/providers/Microsoft.Network/virtualNetworks/$vnetName/subnets/default"
          }
        },
        {
          "name": "zookeepernode",
          "targetInstanceCount": 3,
          "hardwareProfile": {
            "vmSize": "Medium"
          },
          "osProfile": {
            "linuxOperatingSystemProfile": {
              "username": "$userName"
            }
          },
          "virtualNetworkProfile": {
            "id": "/subscriptions/$subscriptionId/resourceGroups/$resourceGroupName/providers/Microsoft.Network/virtualNetworks/$vnetName",
            "subnet": "/subscriptions/$subscriptionId/resourceGroups/$resourceGroupName/providers/Microsoft.Network/virtualNetworks/$vnetName/subnets/default"
          }
        },
        {
          "name": "edgenode1",
          "targetInstanceCount": 1,
          "hardwareProfile": {
            "vmSize": "Standard_D3_v2"
          },
          "osProfile": {
            "linuxOperatingSystemProfile": {
              "username": "$userName"
            }
          },
          "virtualNetworkProfile": {
            "id": "/subscriptions/$subscriptionId/resourceGroups/$resourceGroupName/providers/Microsoft.Network/virtualNetworks/$vnetName",
            "subnet": "/subscriptions/$subscriptionId/resourceGroups/$resourceGroupName/providers/Microsoft.Network/virtualNetworks/$vnetName/subnets/default"
          }
        }
      ]
    },
    "provisioningState": "Succeeded",
    "clusterState": "Running",
    "createdDate": "2017-04-26T07:44:54.4",
    "quotaInfo": {
      "coresUsed": 16
    },
    "connectivityEndpoints": [
      {
        "name": "SSH",
        "protocol": "TCP",
        "location": "$clusterName-ssh.azurehdinsight.net",
        "port": 22
      },
      {
        "name": "HTTPS",
        "protocol": "TCP",
        "location": "$clusterName.azurehdinsight.net",
        "port": 443
      }
    ],
    "tier": "standard"
  }
}

您可以使用 Ambari API 获取边缘节点 IP。当您的模板部署成功后,您可以使用以下脚本来列出边缘节点 IP。

#!/bin/bash
PASSWORD=
CLUSTERNAME=
###list all host private IP
for HOSTNAME in $(curl -u admin:$PASSWORD -sS -G "https://$CLUSTERNAME.azurehdinsight.net/api/v1/clusters/$CLUSTERNAME/hosts" | jq -r '.items[].Hosts.host_name')
do
    IP=$(curl -u admin:$PASSWORD -sS -G "https://$CLUSTERNAME.azurehdinsight.net/api/v1/clusters/$CLUSTERNAME/hosts/$HOSTNAME" | jq -r '.Hosts.ip')
  echo "$HOSTNAME <--> $IP" >>host.txt
done
cat host.txt |grep '^ed'|awk -F\> '{print  }'

host.txt中,您将获得所有主机IP,如下所示。

ed11-******.gx.internal.cloudapp.net <--> 10.4.0.4
ed20-******.gx.internal.cloudapp.net <--> 10.4.0.8
hn0-******.gx.internal.cloudapp.net <--> 10.4.0.18
hn1-******.gx.internal.cloudapp.net <--> 10.4.0.13
wn0-******.gx.internal.cloudapp.net <--> 10.4.0.7
zk1-******.gx.internal.cloudapp.net <--> 10.4.0.12
zk3-******.gx.internal.cloudapp.net <--> 10.4.0.9
zk5-******.gx.internal.cloudapp.net <--> 10.4.0.10

您可以执行如下脚本:

[root@shui home]# ./deploy.sh <password> <clustername>
 10.4.0.4
 10.4.0.8