- vừa được xem lúc

Tích hợp VpcLink với ApiGateway

0 0 3

Người đăng: tuananhhedspibk

Theo Viblo Asia

Dành cho những bạn đọc chưa biết, tôi có một bài viết về việc xây dựng AWS infra cho micro-service tại đây. Trong bài viết đó, tôi chủ động để các tài nguyên như ECS ở bên trong private-subnet nên trong bài viết lần này tôi xin phép được giới thiệu tới bạn đọc cách thức kết nối giữa API routesprivate ecs nêu trên.

VPC Link

VPC Link cho phép kết nối giữa API Routes và các private resources

Tham khảo: https://docs.aws.amazon.com/apigateway/latest/developerguide/http-api-vpc-links.html

Như bạn đọc đã thấy định nghĩa về vpc-link ở trên, nó cho phép chúng ta có thể kết nối giữa API Routes và các private resources.

Nên do đó để giải quyết bài toán Kết nối giữa API routes và private ecs của mình, tôi quyết định sẽ sử dụng vpc-link ở đây.

Thiết kế

Tổng quan chung thì hệ thống của tôi trông sẽ như sau:

1-ALB-Example Hình 1

Các bạn có thể thấy: api-gateway sẽ quản lí các API Route, nên điều mà tôi cần làm lúc này là

Sử dụng vpc-link như một chiếc cầu nối giữa api-gateway và load-balancer

để từ đó phía client có thể tông qua api-gateway để truy cập vào server chạy bên trong private ecs

Triển khai

Bước 1: Tạo vpc-link

Tôi tạo ra vpc-link bằng terraform một cách rất đơn giản như sau:

resource "aws_api_gateway_vpc_link" "main" { name = "vpc-link" description = "vpc-link" // tôi thiết lập để vpc-link kết nối được tới load-balancer thông qua arn target_arns = [aws_lb.main.arn] tags = { Name = "vpc-link" }
}

Bước 2: Thiết lập kết nối giữa api-gateway và vpc-link

Do bản thân api-gateway đã được tạo trước đó bằng aws-cdk nên tôi sẽ không tạo api-gateway bằng terraform nữa.

Mà ở đây tôi sẽ sử dụng aws-cdk để kết nối giữa api-gateway và vpc-lịnk như sau:

import { Integration, IntegrationType, VpcLink, ConnectionType, RestApi
} from 'aws-cdk-lib/aws-apigateway'; const integration = async (scope, id, vpcLinkId, method, uri) => { // Khai báo api-gateway const api = new RestApi(allowMethods: ['OPTIONS', 'GET', 'POST', 'PUT', 'PATCH', 'DELETE']); // Tìm đến vpc-link hiện có trong hệ thống const vpcLink = await VpcLink.fromVpcLinkId(scope, id, vpcLinkId); // Tạo integration (dùng để gắn api-gateway với vpc-link sau này) const integration = new Integration({ type: IntegrationType.HTTP_PROXY, integrationHttpMethod: method, uri, options: { connectionType: ConnectionType.VPC_LINK, vpcLink, }, }); // Gắn integration với resource tương ứng trong api-gateway api.getResource('A').addMethod(method, integration, {});
};

Rất đơn giản như vậy thôi và chúng ta đã có được kết nối "tay ba" giữa

  • api-gateway
  • vpc-link
  • load-balancer

giống như thiết kế được trình bày ở Hình 1 nêu trên.

Tổng kết

Đây là một ghi chép nhanh của cá nhân tôi trong quá trình xây dựng infra cho hệ thống micro-service, hi vọng rằng bài viết này sẽ là một tài liệu tham khảo "nhanh" cho bạn đọc trong quá trình làm việc của mình.

Cảm ơn bạn đọc đã tiếp nhận bài viết, xin hẹn gặp lại ở các bài viết tiếp theo.

Bình luận

Bài viết tương tự

- vừa được xem lúc

PDF Export, cẩn thận với những input có thể truyền vào

Giới thiệu. Dạo gần đây mình tình cờ gặp rất nhiều lỗi XSS, tuy nhiên trang đó lại có sử dụng dữ liệu người dùng input vào để export ra PDF.

0 0 49

- vừa được xem lúc

Giới thiệu về AWS Batch

Khi sử dụng hệ thống cloud service, điều chúng ta thường phải quan tâm đến không chỉ là hiệu suất hoạt động (performance) mà còn phải chú ý đến cả chi phí bỏ ra để duy trì hoạt động của hệ thống. Chắn hẳn là hệ thống lớn hay nhỏ nào cũng đã từng phải dùng đến những instance chuyên để chạy batch thực

0 0 128

- vừa được xem lúc

Tìm hiểu về AWS KMS

1. AWS KMS là gì. Ở KMS bạn có thể lựa chọn tạo symetric key (khóa đối xứng) hoặc asymetric key (khóa bất đối xứng) để làm CMK (Customer Master Key). Sau khi tạo key thì có thể thiết đặt key policy để control quyền access và sử dụng key.

0 0 53

- vừa được xem lúc

AWS VPC cho người mới bắt đầu

Tuần này, tôi trình bày lại những gì tôi đã học được về Virtual Private Cloud (VPC) của Amazon. Nếu bạn muốn xem những gì tôi đã học được về AWS, hãy xem Tổng quan về DynamoDB và Tổng quan về S3. VPC là gì. Những điều cần lưu ý:.

0 0 69

- vừa được xem lúc

AWS Essentials (Phần 6): Guildline SNS Basic trên AWS

Tiếp tục với chuỗi bài viết về Basic AWS Setting, chúng ta tiếp tục tìm hiểu tiếp tới SNS (Simple Notification Service). Đây là một service của AWS cho phép người dùng setting thực hiện gửi email, text message hay push notification tự động tới mobile device dựa trên event người dùng setting phía AWS

0 0 125

- vừa được xem lúc

Sử dụng Amazon CloudFront Content Delivery Network với Private S3 Bucket — Signing URLs

Trong nhiều trường hợp, thì việc sử dụng CDN là bắt buộc. Mình đã trải nghiệm với một số CDN nhưng cuối cùng mình lựa chọn sử dụng AWS CloudFront.

0 0 105