-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat(terraform): vol5504 add single batch job (#158)
* feat(terraform): vol5504 add single batch job * docs: update Terraform docs * attempt to translate between environment variables without the need for TFVars to manage this * feat(terraform): vol5504 add single batch job * feat(terraform): vol5504 add single batch job * feat(terraform): vol5504 add single batch job * docs: update Terraform docs * feat(terraform): vol5504 add single batch job * resolving terraform fmt errors * docs: update Terraform docs * feat(terraform): vol5504 add single batch job * docs: update Terraform docs --------- Co-authored-by: github-actions[bot] <github-actions[bot]@users.noreply.github.com> Co-authored-by: Laurence <[email protected]>
- Loading branch information
1 parent
66ec908
commit 5c8ee05
Showing
4 changed files
with
157 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,134 @@ | ||
|
||
module "batch" { | ||
source = "terraform-aws-modules/batch/aws" | ||
version = "~> 2.0.0" | ||
|
||
instance_iam_role_name = "${var.environment}-batch-app-ecs-instance-role" | ||
instance_iam_role_path = "/batch/" | ||
instance_iam_role_description = "IAM instance role/profile for AWS Batch ECS instance(s)" | ||
instance_iam_role_tags = { | ||
ModuleCreatedRole = "Yes" | ||
} | ||
|
||
service_iam_role_name = "${var.environment}-batch-app-batch-role" | ||
service_iam_role_path = "/batch/" | ||
service_iam_role_description = "IAM service role for AWS Batch" | ||
service_iam_role_tags = { | ||
ModuleCreatedRole = "Yes" | ||
} | ||
|
||
create_spot_fleet_iam_role = false | ||
spot_fleet_iam_role_name = "${var.environment}-batch-app-spot-role" | ||
spot_fleet_iam_role_path = "/batch/" | ||
spot_fleet_iam_role_description = "IAM spot fleet role for AWS Batch" | ||
spot_fleet_iam_role_tags = { | ||
ModuleCreatedRole = "Yes" | ||
} | ||
|
||
compute_environments = { | ||
a_fargate = { | ||
name_prefix = "batch-app-fargate" | ||
|
||
compute_resources = { | ||
type = "FARGATE" | ||
max_vcpus = 4 | ||
|
||
security_group_ids = "${var.environment} =\"dev\" ? format(\"%s/%s\",\"DEV/APP\",upper(var.environment)) : upper(var.environment)}-OLCS-PRI-API-SG" | ||
subnet_ids = ["${var.environment} =\"dev\" ? format(\"%s/%s\",\"DEV/APP\",upper(var.environment)) : upper(var.environment)}-OLCS-PRI-BATCH-1A", "${var.environment} =\"dev\" ? format(\"%s/%s\",\"DEV/APP\",upper(var.environment)) : upper(var.environment)}-OLCS-PRI-BATCH-1B", "${var.environment} =\"dev\" ? format(\"%s/%s\",\"DEV/APP\",upper(var.environment)) : upper(var.environment)}-OLCS-PRI-BATCH-1C"] | ||
|
||
# `tags = {}` here is not applicable for spot | ||
} | ||
} | ||
|
||
b_fargate_spot = { | ||
name_prefix = "batch-app-fargate_spot" | ||
|
||
compute_resources = { | ||
type = "FARGATE_SPOT" | ||
max_vcpus = 4 | ||
|
||
security_group_ids = "${var.environment} =\"dev\" ? format(\"%s/%s\",\"DEV/APP\",upper(var.environment)) : upper(var.environment)}-OLCS-PRI-API-SG" | ||
subnet_ids = ["${var.environment} =\"dev\" ? format(\"%s/%s\",\"DEV/APP\",upper(var.environment)) : upper(var.environment)}-OLCS-PRI-BATCH-1A", "${var.environment} =\"dev\" ? format(\"%s/%s\",\"DEV/APP\",upper(var.environment)) : upper(var.environment)}-OLCS-PRI-BATCH-1B", "${var.environment} =\"dev\" ? format(\"%s/%s\",\"DEV/APP\",upper(var.environment)) : upper(var.environment)}-OLCS-PRI-BATCH-1C"] | ||
# `tags = {}` here is not applicable for spot | ||
} | ||
} | ||
} | ||
|
||
# Job queus and scheduling policies | ||
job_queues = { | ||
low_priority = { | ||
name = "BatchTestLowPriorityFargate" | ||
state = "ENABLED" | ||
priority = 1 | ||
|
||
tags = { | ||
JobQueue = "Low priority job queue" | ||
} | ||
} | ||
|
||
high_priority = { | ||
name = "BatchTestHighPriorityFargate" | ||
state = "ENABLED" | ||
priority = 99 | ||
|
||
fair_share_policy = { | ||
compute_reservation = 1 | ||
share_decay_seconds = 3600 | ||
|
||
share_distribution = [{ | ||
share_identifier = "A1*" | ||
weight_factor = 0.1 | ||
}, { | ||
share_identifier = "A2" | ||
weight_factor = 0.2 | ||
}] | ||
} | ||
|
||
tags = { | ||
JobQueue = "High priority job queue" | ||
} | ||
} | ||
} | ||
|
||
job_definitions = { | ||
job_configuration = { | ||
name = "${var.job_definitions["processQueue"]["job_name"]}-job" | ||
type = "container" | ||
propagate_tags = true | ||
platform_capabilities = ["FARGATE", ] | ||
|
||
container_properties = jsonencode({ | ||
command = var.job_definitions["processQueue"]["command"], | ||
image = var.job_definitions["processQueue"]["image"], | ||
fargatePlatformConfiguration = { | ||
platformVersion = "LATEST" | ||
}, | ||
resourceRequirements = [ | ||
{ type = "VCPU", value = "1" }, | ||
{ type = "MEMORY", value = var.job_definitions["processQueue"]["memory"] }, | ||
], | ||
jobRoleArn = "arn:aws:iam::054614622558:role/vol-app-dev-api-service-20240418150301367500000003" | ||
}) | ||
|
||
attempt_duration_seconds = 60 | ||
retry_strategy = { | ||
attempts = 3 | ||
evaluate_on_exit = { | ||
retry_error = { | ||
action = "RETRY" | ||
on_exit_code = 1 | ||
} | ||
exit_success = { | ||
action = "EXIT" | ||
on_exit_code = 0 | ||
} | ||
} | ||
} | ||
|
||
tags = { | ||
JobDefinition = "BatchTest" | ||
} | ||
} | ||
// tags = local.default_tags | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters