- Newest
- Most votes
- Most comments
If your ECS cluster is private, i.e., you can't access it from the internet, then you need to use VPC Link from API Gateway to get into the VPC. If you are using REST API, it only supports NLB. If you are using an HTTP API, you can use an NLB, ALB or CloudMap (which may be what you want).
If your cluster is exposed to the internet, you can connect API Gateway directly to it, but, API Gateway is not a load balancer, so you will only be able to connect it to a single instance. Also, if your service is exposed to the internet, users can bypass it and access the service directly, so it is not recommended.
Hi,
Check out this blog: https://aws.amazon.com/blogs/architecture/field-notes-serverless-container-based-apis-with-amazon-ecs-and-amazon-api-gateway/
It depicts in full detail what you want to achieve.
Another very detailled example here : https://medium.com/cloud-base/expose-ecs-service-via-api-gateway-part-1-75899439885f
Best,
Didier
Here's how to integrate AWS ECS with API Gateway (REST API) using a private integration, without NLB, Lambda, or other services:
►Prerequisites:
-
An ECS cluster with a running service.
-
An API Gateway with a REST API defined.
-
VPC Setup: Both your ECS cluster and API Gateway must be within the same VPC (Virtual Private Cloud).
►Steps:
• Create a VPC Link:
- In the API Gateway console, navigate to VPN Links.
- Click Create.
- Provide a name for the link and choose your VPC from the dropdown menu.
- Click Create
• Configure Private Integration:
- Go to your REST API in API Gateway.
- Select Resources and choose the resource you want to integrate with your ECS service.
- Click Actions and select Create Method.
- Choose your desired HTTP method (e.g., GET, POST).
- Under Integration Type, select Private integration.
- For Integration HTTP Method, choose the method your ECS service expects (likely POST).
- Under Endpoint Type, select VPC Link.
- Choose the VPC Link you created in step 1.
- For Target, use the following format: arn:aws:ecs:${region}:${account-id}:cluster/${cluster-name}/service/${service-name}:${revision}. Replace the placeholders with your specific information.
- Click Save.
►Explanation:
This approach directly connects your API Gateway to your ECS service within the same VPC. API Gateway requests are routed through the VPC Link to your ECS service, bypassing the need for an NLB or Lambda function.
If you want to know about more information then you can check this-: https://www.nimbleappgenie.com/blogs/aws-marketplace-integration/
Relevant content
- Accepted Answerasked 6 months ago
- asked 2 years ago
- asked a year ago
- AWS OFFICIALUpdated 3 months ago
- AWS OFFICIALUpdated 2 years ago
- AWS OFFICIALUpdated 2 years ago
- AWS OFFICIALUpdated 2 months ago