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

Các loại cân bằng tải trên AWS - Phần 1

0 0 23

Người đăng: Pham Hieu

Theo Viblo Asia

AWS-Elastic-Load-Balancing-AWS-ELB

Trong phần này, chúng ta sẽ cùng tìm hiểu về các bộ cân bằng tải trên AWS. Tiếp theo, chúng ta sẽ đi sâu hơn vào các loại Load Balancer trên AWS, cũng như các tính năng của chúng.

Classic Load Balancer - CLB (v1)

classic-load-balancer

Classic Load Balancer - CLB là phiên bản vân bằng tải đầu tiên được cung cấp bởi AWS vào năm 2009. Nó hoạt động ở lớp ứng dụng, cho phép điều phối các request dạng HTTP, HTTPS, TCP, SSL (secure TCP).

Classic Load Balancer - CLB đã bị loại bỏ và được thay thế bởi các thế hệ kế tiếp.

Mặc dù đã bị loại bỏ, tuy nhiên CLB đã đặt nền móng cũng như cho phép đội ngũ kỹ sư của AWS có thể rút kinh nghiệm, từ đó hoàn thiện được các thế hệ cân bằng tải sau này. Các bộ CLB có các đặc điểm chính có thể kể tới như sau:

  • Hỗ trợ TCP (Layer 4), HTTP & HTTPS (Layer 7).
  • Health Check đã được hỗ trợ ngay từ phiên bản này.
  • Điểm trừ là hostname sẽ bị fixed dạng XXX.region.elb.amazonaws.com, không thể tùy biến.

Application Load Balancer - ALB (v2)

Application Load Balancer - ALB là phiên bản cân bằng tải thứ 2 được cung cấp bởi AWS vào năm 2016. Nó hoạt động ở lớp ứng dụng (Layer 7 - HTTP). Đây cũng là loại Load Balancer được dùng phổ biến nhất trên AWS.
ALB có các đặc điểm chính như sau:

  • Cân bằng tải ở lớp ứng dụng (Layer 7 - HTTP). Giúp điều phối các HTTP Requests tới các máy chủ dịch vụ khác nhau (thường gọi là target groups) hoặc các ứng dụng trên cùng máy chủ (Ví dụ các containers).
  • Hỗ trợ cả HTTP/2 và WebSocket.
  • Cho phép redirects requests từ HTTP sang HTTPS.
  • Cho phép redirect các request tới các dynamic port trên ECS thông qua tính năng Port Mapping. Để so sánh, chúng ta sẽ cần đến nhiều bộ cân bằng tải dạng Classic Load Balancer cho mỗi ứng dụng nếu muốn thực hiện thao tác nói trên.
  • Routing Table: ALB điều phối các request như thế nào?

ALB cung cấp một giải pháp tuyệt vời cho các ứng dụng phân tán, đặc biệt là các ứng dụng microservices hoặc các ứng dụng dựa trên các containers (Docker & Amazon ECS...).

HTTP Based Traffic

HTTP_Based_Traffic

Query Strings/Parameters Routing

Query_Strings_Parameters_Routing

Target Groups: ALB có thể điều phối các requests tới đâu?

  • EC2 instances (Kể cả được quản lý thông qua Auto Scaling Group) – HTTP.
  • ECS tasks - HTTP.
  • Lambda functions - HTTP, tuy nhiên HTTP Request sẽ được chuyển về djang JSON Event.
  • IP addresses - HTTP, tuy nhiên phải là Private IPs.
  • ALB có thể điều phối các request tới nhiều target groups khác nhau.

Một vài lưu ý khác về ALB:

att

  • Khi request được gửi tới ứng dụng thông qua ALB, ứng dụng sẽ không thể nhìn thấy địa chỉ IP của người dùng, mà chỉ nhìn thấy địa chỉ IP của ALB. Địa chỉ IP thật của người dùng sẽ được đặt trong HTTP Header X-Forwarded-For. Ngoài ra, chúng ta cũng có thể lấy thông tin về Port (X-Forwarded-Port) và Giao thức - Protocol (X-Forwarded-Proto).

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 66

- 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 143

- 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 66

- 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 84

- 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 145

- 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 117