Running on AWS Fargate
Important:
- For Single ECS, use IP license.
- For managed ECS, Unlimited License is required. For the license, please contact SearchBlox support.
To use Fargate with ECS to run a series of containerized tasks or steps, follow the below steps:
Important:
- We can get Image URI in two ways:
NOTE: You can follow any one of the above step and Creating a Fargate Cluster is common for both the above steps.
Getting Image URI from AWS Marketplace
- Go to AWS Marketplace and Subcribe to SearchBlox Enterprise Search, by clicking the below link.
- Link to Fargate version
- Click on
Continue to Subscribe
.
data:image/s3,"s3://crabby-images/69473/6947345a47f9887647939c4e18b1a6a73a6538fd" alt=""
- Click on
Continue to Configuration
.
data:image/s3,"s3://crabby-images/53ec6/53ec60b88102d89939ce4ba29c9f43a10b23d1b8" alt=""
- Click on
Continue to Launch
data:image/s3,"s3://crabby-images/32db7/32db70397b4de940f0f29eb397214fc5fbd1c002" alt=""
- Scroll down to the
Container images
section and copy the commands that are shown below as shown in the image.
aws ecr get-login-password
--region us-east-1 | docker login
--username AWS
--password-stdin xxxxxxx.dkr.ecr.us-east-1.amazonaws.com
CONTAINER_IMAGES="xxxxxx.dkr.ecr.us-east-1.amazonaws.com/searchblox/searchblox:v10.7"
for i in $(echo $CONTAINER_IMAGES | sed "s/,/ /g"); do docker pull $i; done
data:image/s3,"s3://crabby-images/5611a/5611aa9c91d598c6b5dcbb2e784fdc156e18cca0" alt=""
- After executing the above command the below response can be seen and copy the last line, which is the
Image URI
used for the next steps.
v10.7: Pulling from searchblox/searchblox
Digest: sha256:a13abcd5f970e253c8be2b7a093c215728046d2f4a0505343710a80bae39801d
Status: Image is up to date for xxxxxx.dkr.ecr.us-east-1.amazonaws.com/searchblox/searchblox:v10.7
xxxxxx.dkr.ecr.us-east-1.amazonaws.com/searchblox/searchblox:v10.7
Importing Custom Docker Image into the Registry
- Sign in to the AWS Management Console and navigate to the Amazon Elastic Container Service console.
- After selecting the ECS Container, select Repositories on the left pane. You will be redirected to Amazon Elastic Container Registry.
- Select Create repository.
data:image/s3,"s3://crabby-images/b395c/b395c32a9572011f711ac03f2250cd2e0f6fbfcf" alt=""
- Select Private and specify the Repository name.
Note:
Name should be same as the Docker image.
data:image/s3,"s3://crabby-images/2fc1c/2fc1c754f80acf3f367a7f8b23cf20b58ecadf6a" alt=""
- Leave everything as default and Create repository.
- Once Repository is Successfully created, select View push commands.
data:image/s3,"s3://crabby-images/b6e35/b6e35c0a31d45d2219db313613b3e9768e2f6cfb" alt=""
- Read the instructions carefully on the page below.
data:image/s3,"s3://crabby-images/b86cd/b86cdb67272bb8f8583bbdd802b8536706952a43" alt=""
Note:
Highlighted text in the above image needs to be changed as per the Docker image Tag name.
-
Execute the following rewritten commands on the Terminal. Simply copy and paste to execute.
NOTE : Before executing the following commands make sure AWS CLI is installed on the terminal.
- Retrieve an authentication token and authenticate your Docker client to your registry.
Use the AWS CLI
aws ecr get-login-password --region us-east-1 | docker login --username AWS --password-stdin 020679151690.dkr.ecr.us-east-1.amazonaws.com
- Build your Docker image using the following command. For information on building a Docker file from scratch see the instructions here . You can skip this step if your image is already built:
docker build -t v10.8.0.5
- After the build completes, tag your image so you can push the image to this repository:
docker tag v10.8.0.5:latest 020679151690.dkr.ecr.us-east-1.amazonaws.com/v10.8.0.5:latest
- Run the following command to push this image to your newly created AWS repository:
docker push 020679151690.dkr.ecr.us-east-1.amazonaws.com/v10.8.0.5:latest
data:image/s3,"s3://crabby-images/fe425/fe42509c5da6c4f845880bee2074a38544487671" alt=""
Creating Fargate Cluster
- Navigate to Main Menu of Amazon ECS.
- Select Clusters to create a new cluster.
data:image/s3,"s3://crabby-images/35741/357412c195b9a0fa514d3646e3afb39ecb0675f5" alt=""
- Select Create cluster.
data:image/s3,"s3://crabby-images/44975/4497584ba252c83513ff73486453d892c159804a" alt=""
- Enter the Cluster name.
- Under Infrastructure, Select AWS Fargate (serverless).
data:image/s3,"s3://crabby-images/87e88/87e88e718651d6a0d62e017ebaddd0457efe8718" alt=""
- Toggle on Use Container Insights, if you want to monitor the CPU and RAM usage. Click on Create button.
data:image/s3,"s3://crabby-images/73c14/73c147ad2abbfe5d29fc97b5176080032e474170" alt=""
- Navigate back to Amazon ECS Main Menu and select Task definitions.
data:image/s3,"s3://crabby-images/b7482/b7482b80ee6527a763e32c8bdd0f8f59e664748b" alt=""
- Under Task definitions, select Create new task definition.
data:image/s3,"s3://crabby-images/c5608/c5608e3158d1cefb0dca7c4d1208ab13a4474323" alt=""
- Specify the Task definition family and choose AWS Fargate.
data:image/s3,"s3://crabby-images/d180a/d180a4c7d6bb01650a80b8ed63c41e79bf2c1dd4" alt=""
- Choose Linux/86_64 and specify the CPU size as 16 CPU and Memory as 64GB (As per the docker image size).
- Create a task role in AWS IAM. Allow full permissions for ECS and Cloud Watch.
data:image/s3,"s3://crabby-images/0ad53/0ad533efa2a421d912dc5ac9bafab00657104298" alt=""
- To create a role in AWS, navigate to IAM service, click on left-side panel ROLES. Click on Create a Role. Select Trusted entity type as AWS Service and select usecase as lamda, click on Next button.
data:image/s3,"s3://crabby-images/bf1cd/bf1cd1256d1fec865832e0e129477e88762899bb" alt=""
- In the Add Permission section search for AmazonECSTaskExecutionRolePolicy.
data:image/s3,"s3://crabby-images/8c627/8c62798ce5bdd825e5ff5a01335482b0faf9298b" alt=""
- Select the ecsTaskExecutionRole created in IAM console.
data:image/s3,"s3://crabby-images/51773/51773e29952a4d049237e014e36a765a7f01380b" alt=""
NOTE: Task size should be 16 CPU and 64GB Memory.
- Under Container-1 setting, specify the Name and paste the Image URI copied from the repositories page. Example :
xxxxxxxxx.dkr.ecr.us-east-1.amazonaws.com/<repository name>/searchblox:v10.8.0.5
data:image/s3,"s3://crabby-images/42978/429785e5d51cabb23a0841c500ab6175d260273b" alt=""
- Under Port mappings, add the port numbers (8443, 8444, 8446, 9200) and set the App protocol as HTTP.
- Allocate Memory hard limit as 40, Memory soft limit as 35 and the CPU cores as 16 CPU, can be increased based on the requirements.
- Storage can be increased as shown in the below image.
data:image/s3,"s3://crabby-images/8b432/8b4323f9bb519d15a4d2d02105fe2abaebed8ac9" alt=""
- Select Create.
data:image/s3,"s3://crabby-images/17bfa/17bfa21226013961c88df3dc414c42e5dc7e51c9" alt=""
Running The Task
- The below page will appear after creating task definition.
- Click on Deploy drop down box and select Run task.
data:image/s3,"s3://crabby-images/e6010/e60104e0045cac2c75129262ab4d49b7043159be" alt=""
- Choose the Existing cluster name.
- Under Compute options, select Capacity provider strategy.
data:image/s3,"s3://crabby-images/b865b/b865b60d4bc8114b32ddc876a795ae29efb0e8cf" alt=""
- Capacity provider is FARGATE,
- Set the Base to 1.
- Set Platform revision to LATEST.
data:image/s3,"s3://crabby-images/9a385/9a3854ac20789fc7d9fdd18924a067fbf1a831e5" alt=""
- The number of Desired tasks to be lauched, can be changed. The Task name should be unique.
data:image/s3,"s3://crabby-images/97d4a/97d4ab25bde0b2688e3d984fd8f75031f52057b2" alt=""
- Under Networking, choose the default VPC ,Subnets or based on your specific requirements.
data:image/s3,"s3://crabby-images/49e99/49e99b5de3244ce746e08ebeb0fe5f7fe269b5e9" alt=""
- Select Create new security group and specify the Security group name and Security group description.
- Under Inbound rules for security groups, select Custom as Type.
- Add Port range (8443,8444,9200)
- Select Source as Anywhere.
data:image/s3,"s3://crabby-images/1c7c3/1c7c34970e090f30d6b071d8d656f5b48323e7b8" alt=""
- Public IP should be Turned on.
- Select Create.
data:image/s3,"s3://crabby-images/a86b5/a86b596551c2229d18e746483f778fb1dbfcd38d" alt=""
- After the task is created, it will navigate to the below page.
- The status of the task can be checked under Last status.
- Wait until the task gets Completed.
data:image/s3,"s3://crabby-images/971c0/971c0b2f1e91224ab757ccc51407988483f05583" alt=""
- If the task is completed, the Public IP can be obtained under the Network binding section.
data:image/s3,"s3://crabby-images/aa841/aa841e54973d6281f4e2c50186c10e7c21273f6a" alt=""
- To access the SearchBlox console, use the Public IP on the browser
https://<Public IP>:8443/console
Important:
- If you are not able to access the SearchBlox Console, check the security group.
Updated about 1 month ago