UNPKG

@cloud-carbon-footprint/aws

Version:

The core logic to get cloud usage data and estimate energy and carbon emissions from Amazon Web Services.

116 lines (105 loc) 3.06 kB
/* * © 2021 Thoughtworks, Inc. */ import { ComputeUsage, ServiceWithCPUUtilization, Cost, } from '@cloud-carbon-footprint/core' import { getComputeUsage } from './ComputeUsageMapper' import { CACHE_NODE_TYPES } from './AWSInstanceTypes' import { ServiceWrapper } from './ServiceWrapper' import { getCostFromCostExplorer } from './CostMapper' import { GetMetricDataCommandInput } from '@aws-sdk/client-cloudwatch' import { GetCostAndUsageCommandInput } from '@aws-sdk/client-cost-explorer' export default class ElastiCache extends ServiceWithCPUUtilization { serviceName = 'ElastiCache' constructor(private readonly serviceWrapper: ServiceWrapper) { super() } async getUsage( start: Date, end: Date, region: string, ): Promise<ComputeUsage[]> { const cloudWatchParams: GetMetricDataCommandInput = { StartTime: start, EndTime: end, MetricDataQueries: [ { Id: 'cpuUtilizationWithEmptyValues', Expression: "SEARCH('{AWS/ElastiCache} MetricName=\"CPUUtilization\"', 'Average', 3600)", ReturnData: false, }, { Id: 'cpuUtilization', Expression: 'REMOVE_EMPTY(cpuUtilizationWithEmptyValues)', }, ], ScanBy: 'TimestampAscending', } const metricDataResponses = await this.serviceWrapper.getMetricDataResponses(cloudWatchParams) const costExplorerParams: GetCostAndUsageCommandInput = { TimePeriod: { Start: start.toISOString().substr(0, 10), End: end.toISOString().substr(0, 10), }, Filter: { And: [ { Dimensions: { Key: 'USAGE_TYPE_GROUP', Values: ['ElastiCache: Running Hours'], }, }, { Dimensions: { Key: 'REGION', Values: [region] } }, ], }, Granularity: 'DAILY', GroupBy: [ { Key: 'USAGE_TYPE', Type: 'DIMENSION', }, ], Metrics: ['UsageQuantity'], } const costAndUsageResponses = await this.serviceWrapper.getCostAndUsageResponses(costExplorerParams) return getComputeUsage( metricDataResponses, costAndUsageResponses, CACHE_NODE_TYPES, ) } async getCosts(start: Date, end: Date, region: string): Promise<Cost[]> { const costExplorerParams: GetCostAndUsageCommandInput = { TimePeriod: { Start: start.toISOString().substr(0, 10), End: end.toISOString().substr(0, 10), }, Filter: { And: [ { Dimensions: { Key: 'USAGE_TYPE_GROUP', Values: ['ElastiCache: Running Hours'], }, }, { Dimensions: { Key: 'REGION', Values: [region] } }, ], }, Granularity: 'DAILY', GroupBy: [ { Key: 'USAGE_TYPE', Type: 'DIMENSION', }, ], Metrics: ['AmortizedCost'], } return getCostFromCostExplorer(costExplorerParams, this.serviceWrapper) } }