AWS locations installation
Run a Control Plane on AWS using Elastic Container Service (ECS) and Fargate, to set up your Private Locations and run load generators in your own AWS network.
AWS Elastic Container Service (ECS) is a managed container orchestration service available on AWS. In this example:
- we use Amazon ECS to configure a service to run the Gatling Control Plane
- ECS runs our Docker containers on the AWS Fargate infrastructure
- the Control Plane configuration file is loaded from an AWS S3 bucket
This is only an example. You could, for instance, use ECS to run containers on Amazon EC2, or mount the configuration file from Amazon EFS.
S3 bucket
In the AWS management console, from the Services menu, open S3 (or search for “S3” in the search bar). Click Create bucket.
Choose a name for the bucket, and the region where it will be stored.
Configure other options as preferred. If in doubt, keep “ACLs disabled” and “Block all public access”; we will need to allow access to the bucket with a policy.
Click Create bucket.
You can then upload your Control Plane configuration file to the bucket.
IAM role
We need an IAM role which will allow an ECS task to:
- download the Control Plane’s configuration file stored in an S3 bucket
- spawn new load generators on EC2 when running a simulation
- when IAM profile configured, allow the Control Plane to pass role
Policies
In the AWS management console, from the Services menu, open IAM (or search for “IAM” in the search bar). Click on Access management > Policies, and then on Create policy.
GatlingControlPlaneConfInitContainerPolicy
allows init container to download Control Plane configuration from S3.
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"s3:GetObject"
],
"Resource": "arn:aws:s3:::{BucketName}/{ObjectName}"
}
]
}
{BucketName}
with the bucket where you uploaded the Control Plane configuration and {ObjectName}
with the name of the entry in the bucket.GatlingControlPlaneEc2Policy
allows the Control Plane to deploy a load generator on EC2.
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"ec2:CreateTags",
"ec2:RunInstances"
],
"Resource": [
"arn:aws:ec2:*:*:instance/*",
"arn:aws:ec2:*:*:network-interface/*",
"arn:aws:ec2:*:*:security-group/*",
"arn:aws:ec2:*:*:subnet/*",
"arn:aws:ec2:*:*:volume/*",
"arn:aws:ec2:*::image/*"
]
},
{
"Sid": "EnforceGatlingTag",
"Effect": "Deny",
"Action": "ec2:RunInstances",
"Resource": "arn:aws:ec2:*:*:instance/*",
"Condition": {
"StringNotLike": {
"aws:RequestTag/Name": "GATLING_LG_*"
}
}
},
{
"Effect": "Allow",
"Action": "ec2:TerminateInstances",
"Resource": "arn:aws:ec2:*:*:instance/*",
"Condition": {
"StringLike": {
"ec2:ResourceTag/Name": "GATLING_LG_*"
}
}
},
{
"Effect": "Allow",
"Action": [
"ec2:DescribeImages",
"ec2:DescribeInstances"
],
"Resource": "*"
}
]
}
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"ec2:DisassociateAddress",
"ec2:AssociateAddress"
],
"Resource": "arn:aws:ec2:*:*:instance/*",
"Condition": {
"StringLike": {
"ec2:ResourceTag/Name": "GATLING_LG_*"
}
}
},
{
"Effect": "Allow",
"Action": [
"ec2:DisassociateAddress",
"ec2:AssociateAddress"
],
"Resource": [
"arn:aws:ec2:{Region}:{Account}:elastic-ip/{ElasticIpAllocationId}"
]
},
{
"Effect": "Allow",
"Action": "ec2:DescribeAddresses",
"Resource": "*"
}
]
}
arn:aws:ec2:{Region}:{Account}:elastic-ip/{ElasticIpAllocationId}
are the Amazon Resource Names (ARN) of the allocated elastic IPs you configured in the private locations.The following policy is required only if you have configured an iam-instance-profile in the AWS private location in Control Plane configuration.
IAM Instance Profile on AWS private location allow to assign that role to all load generator instances spawned for that private location
GatlingControlPlaneIAMPolicy
allows the Control Plane to pass an IAM instance profile role to a deployed a load generator on EC2.
{
"Version": "2012-10-17",
"Statement": [
{
"Action": [
"iam:PassRole"
],
"Effect": "Allow",
"Resource": [
"arn:aws:iam::{Account}:role/{RoleNameWithPath}"
]
}
]
}
Role
Create a role GatlingControlPlaneRole
that will be the Task IAM role: the permissions granted in the IAM role are assumed by the containers running in the task.
Amazon Elastic Container Service (ECS)
Tasks
Go to Amazon Elastic Container Service, under Task definitions, click on Create a new task definition > Create new task definition with JSON.
Use the following JSON for the Amazon ECS Task, but first replace the following values:
- Replace
{BucketName}
with the bucket where you uploaded the Control Plane Configuration, and{ObjectName}
with the name of the entry in the bucket. - Replace
{GatlingControlPlaneRole ARN}
with the ARN of the previously created GatlingControlPlaneRole . (ARN can be copied to the clipboard from the role page, IAM > Roles > GatlingControlPlaneRole ) - Replace
{ecsTaskExecutionRole}
with the ARN of the AWS default role ecsTaskExecutionRole. (ARN can be copied to clipboard from the role page, IAM > Roles > ecsTaskExecutionRole)
{
"family": "gatling-control-plane-task",
"containerDefinitions": [
{
"name": "conf-loader-init-container",
"image": "amazon/aws-cli",
"cpu": 0,
"portMappings": [],
"essential": false,
"entryPoint": [
"aws",
"s3",
"cp",
"s3://{BucketName}/{ObjectName}",
"/app/conf/control-plane.conf"
],
"environment": [],
"mountPoints": [
{
"sourceVolume": "control-plane-conf",
"containerPath": "/app/conf",
"readOnly": false
}
],
"volumesFrom": [],
"readonlyRootFilesystem": false
},
{
"name": "control-plane",
"image": "gatlingcorp/control-plane:latest",
"cpu": 0,
"portMappings": [],
"essential": true,
"environment": [],
"mountPoints": [
{
"sourceVolume": "control-plane-conf",
"containerPath": "/app/conf",
"readOnly": true
}
],
"volumesFrom": [],
"dependsOn": [
{
"containerName": "conf-loader-init-container",
"condition": "SUCCESS"
}
],
"workingDirectory": "/app/conf"
}
],
"taskRoleArn": "{GatlingControlPlaneRole ARN}",
"executionRoleArn": "{ecsTaskExecutionRole}",
"networkMode": "awsvpc",
"volumes": [
{
"name": "control-plane-conf",
"host": {}
}
],
"requiresCompatibilities": [
"FARGATE"
],
"cpu": "1024",
"memory": "3072"
}
Cluster and service
Create a cluster named gatling-control-plane-cluster
.
In that cluster, create a service named gatling-control-plane-service
.
Keep the configuration as default, and update deployment configuration with:
- Family:
gatling-control-plane-task
- Revision: Latest (and only) one
Update
In order to update your control plane container to the latest version,
go to the service package (here, gatling-control-plane-service
) and click on Update service
button.
Then, check the Force new deployment
checkbox and click on Update
.
latest
image of the gatlingcorp/control-plane
when they start.
If you need to target a specific version tag, you’ll have to create a new revision of your task definition with the updated version and then redeploy it.Enable CloudWatch Logs
You can use Amazon CloudWatch Logs to monitor, store, and access log files from your Control Plane deployed on Amazon ECS, which is useful for debugging.
Add CloudWatch Logs Policy
In the AWS Management Console, open the IAM service from the Services menu or by searching for “IAM” in the search bar. Navigate to Access management > Policies, then click Create policy. GatlingControlPlaneLogsPolicy
allows the Control Plane service to push its logs to CloudWatch.
Finally, attach the policy to the control plane role.
{
"Version": "2012-10-17",
"Statement": [
{
"Action": [
"logs:CreateLogGroup",
"logs:CreateLogStream",
"logs:PutLogEvents"
],
"Effect": "Allow",
"Resource": "*"
}
]
}
Modify JSON Task Definition
Go to Amazon Elastic Container Service, under task definitions, select your task definition and its latest revision, then click Create new revision > Create new revision with JSON.
Here’s how you can modify the JSON for the Amazon ECS task definition by adding the logConfiguration
object to the control-plane container definition.
Make sure to replace {ServiceName} and {Region} with the actual service name and region values.
{
"family": "gatling-control-plane-task",
"containerDefinitions": [
// Init container definition
{
// Existing control plane container definition
"name": "control-plane",
// Add the logConfiguration object
"logConfiguration": {
"logDriver": "awslogs",
"options": {
"awslogs-group": "/ecs/{ServiceName}",
"awslogs-region": "{Region}",
"awslogs-stream-prefix": "ecs"
}
}
}
]
}
Your Control Plane is up and running!
If you kept the default logging configuration, the control plane’s logs are sent to Amazon CloudWatch, in a log group named /ecs/<task definition name>
.
After a short time, you should see your Control Plane get the Up status in Gatling Enterprise Cloud.
You can now configure a simulation to run on one or more of this Control Plane’s locations!
Deploy infrastructure using Terraform
Gatling provides Terraform modules to set up AWS infrastructure for Private Locations. One module specifies the load generator location(s), and the second module deploys the control plane. To use the Terraform module, visit our dedicated GitHub repository