Как получить стоимость любого экземпляра EC2, используя java-sdk - PullRequest
0 голосов
/ 27 октября 2019

Я хочу получить данные об использовании и стоимости моих экземпляров EC2 с помощью API-интерфейса Cost Explorer.

Я могу получить данные об использовании и стоимости успешно, но эти затраты и использование включают сумму использования, выполненную EC2. экземпляры и тома EBS, поэтому я хотел разделить стоимость, используя usage_type_group, например EC2 :Running Hours, но всякий раз, когда я передаю это, я не получаю никакого значения. Если я удаляю это, я получаю значение с полным использованием и стоимостью.

DimensionValues dimensions = new DimensionValues();
        dimensions.setKey("USAGE_TYPE_GROUP");
        Collection<String> values = new ArrayList<>();
        values.add("EC2 : Running Hours");
        dimensions.setValues(values);
        filter.setDimensions(dimensions);
        GetCostAndUsageRequest getCostAndUsageRequest = new GetCostAndUsageRequest().withGroupBy(groupBy)

                .withTimePeriod(dateInterval).withGranularity(Granularity.MONTHLY)
                .withFilter(filter)
                .withMetrics("UsageQuantity")
                .withMetrics("BlendedCost");

        try {
            costInformation = costExplorer.getCostAndUsage(getCostAndUsageRequest);
        } catch (AWSCostExplorerException ex) {
            logger.error("cost fetch details failed from cost explorer " + ex.getErrorMessage());
        }

1 Ответ

0 голосов
/ 29 октября 2019

Попробуйте это. Я сделал это и получил некоторую платежную информацию EC2.

void test_costDetails() {
        Expression expression = new Expression();
        DimensionValues dimensions = new DimensionValues();
        dimensions.withKey(Dimension.SERVICE);
        dimensions.withValues("EC2 - Other");

        expression.withDimensions(dimensions);
        GetCostAndUsageResult result = costExplorer.getCostAndUsage(new GetCostAndUsageRequest().withTimePeriod(
                new DateInterval().withStart("2019-10-01").withEnd("2019-10-29")).withGranularity("DAILY").withMetrics(
                        "BlendedCost").withFilter(expression));

        result.getResultsByTime().forEach(r -> {
            System.out.println(r);
        });
    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...