Disclaimer
While Joget does not officially support running on ECS, this guide act as a proof of concept to deploy Joget on ECS. Please visit AWS official documentation website for support and information.
Prerequisites
- An AWS Account
- Installed AWS CLI
...
Create Elastic File Storage(EFS)
Reference: https://docs.aws.amazon.com/efs/latest/ug/gs-step-two-create-efs-resources.html
Since Fargate storage is ephemeral(volatile), you will need to utilize EFS in order to persist the storage
...
Create ECS Task Execution Role
Reference: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task_execution_IAM_role.html#create-task-execution-role
- Go to Identity And Access Management(IAM) console.
- On sidebar, click Roles.
- Click Create Role.
data:image/s3,"s3://crabby-images/d4c00/d4c0064aa96302d33ee83026f1817b079a4d0781" alt=""
- Choose AWS Service under Trusted Entity Type.
data:image/s3,"s3://crabby-images/b01a7/b01a71a44a664bc8fde8eb91b98d29ede51b81ab" alt=""
- Under Use Case, search and choose Elastic Container Service and choose Elastic Container Service Task and click Next.
data:image/s3,"s3://crabby-images/e4224/e422473ec0c845c6aa35c44ad65f0f9f3d4a07bb" alt=""
- Under Permission Policies, choose AmazonECSTaskExecutionRolePolicy and AmazonSSMFullAccess. Then click Next.
- Enter the Role Name and Description, and review the permissions.
- Click Create Role.
Creating ECS Cluster
Reference: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/create-cluster-console-v2.html
- Go to Elastic Container Service(ECS) console.
data:image/s3,"s3://crabby-images/2bc10/2bc102d733874e9aa1d57e2a54212fa7d63c8ef6" alt=""
- Click Create Cluster.
data:image/s3,"s3://crabby-images/4845a/4845a67311559eb9a124bf27a54edcbe36d8b754" alt=""
- Enter the Cluster Name.
- Choose the Infrastructure (Fargate, EC2, External).
- Click Create.
Create ECS Task Definition
Reference: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/create-task-definition.html#json-validate-for-create
- On the sidebar, click Task Definition.
data:image/s3,"s3://crabby-images/f76bd/f76bdc0e2b0c7f6b4ca510198b6a4fa799ff9cc8" alt=""
- Click New Create Task Definition.
data:image/s3,"s3://crabby-images/94fc8/94fc861cc3304087cbaf5bd11157bfe1c1f9ed85" alt=""
- Enter the Task Definition name.
- On Infrastructure Requirements, choose the launch type and specify the specs required.
data:image/s3,"s3://crabby-images/f955b/f955b22a5c9afbe58b82dab89b6ae867952b8a16" alt=""
- Under Task Role, choose the role created in Create ECS Task Execution Role.
- Under Task Execution Role, choose the role created in Create ECS Task Execution Role.
- Under container, enter the container name.
- Use jogetworkflow/joget-dx8-tomcat9 for the image.
- Enter 8080 and 9080 for Container Port.
data:image/s3,"s3://crabby-images/63f56/63f56f656a62a682e66999c249be0d82587e029c" alt=""
- Add the following Environment Variable:
- Key: JAVA_OPTS
- Value: ${JAVA_OPTS_MEMORY} -Dwflow.home=${WFLOW_HOME} -Dwflow.systemkey=domain -javaagent:${LIB_HOME}/wflow-cluster.jar -javaagent:${LIB_HOME}/aspectjweaver-${ASPECTJ_VERSION}.jar -javaagent:${LIB_HOME}/glowroot/glowroot.jar "
data:image/s3,"s3://crabby-images/a8738/a87385931e2bc52b86fc73cd2cf0d8da3c08ba37" alt=""
- Under Storage, click Add Volume.
data:image/s3,"s3://crabby-images/00aa2/00aa28ffbeaa536ae0fde2c749f9f53b5cf42376" alt=""
- Enter the volume name, and choose EFS as Volume Type.
- Choose the EFS on File System ID.
- Enter / as the root directory.
Image Added
- Under Container Mount Points, lick Add Mount Point
- Select Container and Source Volume
- Enter Container Path as /opt/joget/wflowas the root directory.
Image Removed
Image Added
- Click Click Create.
Create ECS Service(HTTP)
Reference: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/create-service-console-v2.html
If you wish to setup Joget with HTTPS right away, click here
...
Updating Permission on Joget wflow folder
Reference: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/ecs-exec.html
Updating ECS Service to Allow execute-command
...
Deploy Joget on ECS Fargate with HTTPS Support
Reference: https://docs.aws.amazon.com/elasticloadbalancing/latest/application/create-https-listener.html
Request SSL Certificate from Amazon Certificate Manager(ACM)
...