Skip to content

Commit

Permalink
Merge branch 'main' into feature/waf-rules
Browse files Browse the repository at this point in the history
  • Loading branch information
TheOrangePuff committed Nov 16, 2023
2 parents 776f379 + 8ef5d55 commit c14b6bc
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 7 deletions.
26 changes: 19 additions & 7 deletions packages/graphql-mesh-server/lib/fargate.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@ import * as ecr from "aws-cdk-lib/aws-ecr";
import * as ecsPatterns from "aws-cdk-lib/aws-ecs-patterns";
import * as iam from "aws-cdk-lib/aws-iam";
import * as ssm from "aws-cdk-lib/aws-ssm";
import * as auto_scaling from "aws-cdk-lib/aws-autoscaling";
import { Port, SecurityGroup, IVpc, Vpc } from "aws-cdk-lib/aws-ec2";
import { RedisService } from "./redis-construct";
import {
Expand All @@ -17,6 +16,7 @@ import {
WebApplicationFirewall,
} from "./web-application-firewall";
import { CfnIPSet, CfnWebACL } from "aws-cdk-lib/aws-wafv2";
import { ScalingInterval, AdjustmentType } from "aws-cdk-lib/aws-autoscaling";

export interface MeshServiceProps {
/**
Expand Down Expand Up @@ -85,6 +85,16 @@ export interface MeshServiceProps {
* Defaults to 10
*/
rateLimitPriority?: number;
/**
* Pass custom cpu scaling steps
* Default value:
* [
* { upper: 30, change: -1 },
* { lower: 50, change: +1 },
* { lower: 85, change: +3 },
* ]
*/
cpuScalingSteps?: ScalingInterval[];
}

export class MeshService extends Construct {
Expand Down Expand Up @@ -294,15 +304,17 @@ export class MeshService extends Construct {
maxCapacity: props.maxCapacity || 5,
});

const cpuScalingSteps = props.cpuScalingSteps || [
{ upper: 30, change: -1 },
{ lower: 50, change: +1 },
{ lower: 85, change: +3 },
];

const cpuUtilization = fargateService.service.metricCpuUtilization();
scaling.scaleOnMetric("auto-scale-cpu", {
metric: cpuUtilization,
scalingSteps: [
{ upper: 30, change: -1 },
{ lower: 50, change: +1 },
{ lower: 85, change: +3 },
],
adjustmentType: auto_scaling.AdjustmentType.CHANGE_IN_CAPACITY,
scalingSteps: cpuScalingSteps,
adjustmentType: AdjustmentType.CHANGE_IN_CAPACITY,
});
}
}
11 changes: 11 additions & 0 deletions packages/graphql-mesh-server/lib/graphql-mesh-server.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import { CfnCacheCluster } from "aws-cdk-lib/aws-elasticache";
import * as ssm from "aws-cdk-lib/aws-ssm";
import { AWSManagedRule } from "./web-application-firewall";
import { CfnWebACL } from "aws-cdk-lib/aws-wafv2";
import { ScalingInterval } from "aws-cdk-lib/aws-autoscaling";

export type MeshHostingProps = {
/**
Expand Down Expand Up @@ -58,6 +59,16 @@ export type MeshHostingProps = {
* SSM values to pass through to the container as secrets
*/
secrets?: { [key: string]: ssm.IStringParameter | ssm.IStringListParameter };
/**
* Pass custom cpu scaling steps
* Default value:
* [
* { upper: 30, change: -1 },
* { lower: 50, change: +1 },
* { lower: 85, change: +3 },
* ]
*/
cpuScalingSteps?: ScalingInterval[];
/**
* ARN of the SNS Topic to send deployment notifications to
*/
Expand Down

0 comments on commit c14b6bc

Please sign in to comment.