How one can Deploy a Java Utility in AWS ECS utilizing Terraform


With a purpose to deploy a Java software into AWS ECS (Elastic Container Service) utilizing Terraform, we have to think about a number of various things.

Step 1 – Java Utility

Create a file known as HelloWorld.java and add the next code to it:

public class HelloWorld {
    public static void predominant(String[] args) {
        System.out.println("Hi there, World!");
    }
}

We now must construct our class as follows:

javac HelloWorld.java

As soon as that is accomplished, we are able to bundle our software right into a jar file:

jar cvf my-app.jar HelloWorld.class

Step 2 – Dockerfile

Subsequent create a file known as Dockerfile and replica the next code into it:

FROM openjdk:11-jre-slim

WORKDIR /app

COPY goal/my-app.jar /app

CMD ["java", "-jar", "my-app.jar"]

Be aware that goal/my-app.jar on this code is the relative path from the Dockerfile to the my-app.jar that we packaged in step 1 above.

Step 3 – Terraform

Subsequent we are going to concentrate on the Terraform. To do that, we are able to both create completely different Terraform information, however on this instance, we are going to merely create a single file known as predominant.tf.

On this file, we are going to first create an ECS activity definition:

useful resource "aws_ecs_task_definition" "my_task_definition" {
  household                   = "my-task-definition"
  container_definitions    = jsonencode([
    {
      name      = "my-container"
      image     = "my-docker-image"
      cpu       = 256
      memory    = 512
      portMappings = [
        {
          containerPort = 8080
          hostPort      = 8080
        }
      ]
    }
  ])
}

Adopted by an ECS service:

useful resource "aws_ecs_service" "my_service" {
  title            = "my-service"
  cluster         = aws_ecs_cluster.my_cluster.id
  task_definition = aws_ecs_task_definition.my_task_definition.arn
  desired_count   = 1

  network_configuration {
    subnets          = [aws_subnet.my_subnet.id]
    security_groups  = [aws_security_group.my_security_group.id]
    assign_public_ip = true
  }
}

Step 4 – Operating the Terraform

Now we have to run the Terraform code, which we are able to do from the terminal as follows:

terraform init
terraform apply

Leave a Reply

Your email address will not be published. Required fields are marked *