0

如何使用 Java 或 Rest API 获取云服务(托管服务)诊断数据?

我们可以从 Azure Portal for Roles 获取 DiagnosticsConnectionString,并使用它查询 WADPerformanceCounter 表(存储 API)。

执行时出现以下异常:

查询:java.util.NoSuchElementException:枚举结果时发生错误,请查看原始异常以获取详细信息。在 com.microsoft.azure.storage.core.LazySegmentedIterator.hasNe‌​xt(LazySegmentedIter‌​ator.java:113) 在 TestStorage.main(TestStorage.java:225) 引起:com.microsoft.azure.storage.table.TableServiceException : 错误的请求

4

1 回答 1

1

@Prit,您的问题中没有任何代码,因此我无法弄清楚是由什么引起的问题。

所以我在这里发布我的步骤和代码作为帮助的参考。

  1. 在 Azure 管理门户的云服务选项卡中复制DIAGNOSTICS CONNECTION STRINGS云服务的一个角色,CONFIGURE连接字符串的格式为DefaultEndpointsProtocol=https;AccountName=<storage-account-name>;AccountKey=<storage-key>.

  2. 使用 GUI 工具Micorsoft Azure Storage Explorer查找和查看表格WADPerformanceCounter

在此处输入图像描述

  1. 用于检索所有诊断数据的 Java 代码如下。

    import com.microsoft.azure.storage.CloudStorageAccount;
    import com.microsoft.azure.storage.table.CloudTable;
    import com.microsoft.azure.storage.table.CloudTableClient;
    import com.microsoft.azure.storage.table.TableQuery;
    import com.microsoft.azure.storage.table.TableServiceEntity;
    
    public class WADPerformanceCounterReader {
    
        public static final String storageConnectionString = 
            "DefaultEndpointsProtocol=https;"+
            "AccountName=<storage-account-name>;"+
            "AccountKey=<storage-key>";
    
        public static void main(String[] args) {
            try {
                // Retrieve storage account from connection-string.
                CloudStorageAccount storageAccount = CloudStorageAccount.parse(storageConnectionString);
    
                // Create the table client.
                CloudTableClient tableClient = storageAccount.createCloudTableClient();
    
                CloudTable cloudTable = tableClient.getTableReference("WADPerformanceCountersTable");
                TableQuery<TableServiceEntity> query = TableQuery.from(TableServiceEntity.class);
                for (TableServiceEntity entity : cloudTable.execute(query)) {
                    System.out.println(entity.getPartitionKey()+"\t"+entity.getRowKey());
               }
            } catch (Exception e) {
                // Output the stack trace.
                e.printStackTrace();
            }
        }
    
    }
    

希望能帮助到你。

于 2016-08-31T10:09:20.820 回答