Skip to content

NimTechnology

Trình bày các công nghệ CLOUD một cách dễ hiểu.

  • Kubernetes & Container
    • Docker
    • Kubernetes
      • Ingress
    • Helm Chart
    • Isito-EnvoyFilter
    • Apache Kafka
      • Kafka
      • Kafka Connect
      • Lenses
    • Vault
    • Longhorn – Storage
    • VictoriaMetrics
  • CI/CD
    • ArgoCD
    • ArgoWorkflows
    • Spinnaker
    • Jenkins
  • Coding
    • Terraform
      • GCP – Google Cloud
      • AWS – Amazon Web Service
    • Golang
    • Laravel
    • Jquery & JavaScript
    • Git
    • Selenium
  • Log & Monitor
    • Prometheus
    • Grafana
    • ELK
      • Kibana
      • Logstash
  • BareMetal
  • Toggle search form

[Ingress-nginx/GRPC] Let’s practice the load balancing with Ingress-Nginx and GRPC together

Posted on March 7, 2022March 8, 2022 By nim No Comments on [Ingress-nginx/GRPC] Let’s practice the load balancing with Ingress-Nginx and GRPC together

Sau khi chém gió đông tây thì có nhiều anh em còn hoài nghi là liệu Ingress-Nginx có load balancing cho protocol là GRPC hay ko?

Bữa trước chúng ta được 1 sư huynh chỉ code GPRC rồi giờ test thử sem sao!
Public GRPC via ingress-nginx.
Và tham khoả thêm bài này
https://dev.to/techschoolguru/load-balancing-grpc-service-with-nginx-3fio

Anh có thể coi video này để biết là trong case nào thì ta nên chọn GRPC.

Mô hình chúng ta sẽ có client, server GRPC và ở giữa là Ingress-nginx

Server Streaming API
Client sẽ gửi 1 request và nhận nhiều response từ server.

Lúc này mỗi client sẽ gửi 1 request đến server
Server trả nhiều response về cho client

Mình mới chôm được hình nhìn xịn sò hơn

Và mình thấy là Ingress-nginx đang load balancing ngon cho GRPC mode Server Streaming API

Tại 1 thời điểm. Client A nhận được response của server B
Còn client B nhận được response của Server C

Vì một số lý do kĩ thuật chúng ta đi đến Bi-Directional Streaming API

Trên 1 stream thì server và client sẽ gửi cho nhau nhiều request cho nhau.

Ở đây, thì anh đó chỉ cách tìm số lớn nhất trong a list số

Lần 1st: send 5 => số lớn nhất 5
Lần 2nd: send 10 => số lớn nhất 10 là lớn nhất trong list [5, 10]
Lần 3rd: send 12 => số lớn nhất 12 là lớn nhất trong list [5, 10, 12]
Lần 4th: send 3 => số lớn nhất 12 là lớn nhất trong list [5, 10, 12, 3]
….

Đây là log mình lấy từ client

Bạn thấy phần mình khoang thì
mỗi stream của 1 client -> ingress-nginx sẽ đưa đến 1 server khác nhau.

Lâu lâu cũng có tý lỗi
mình chưa xác định rõ được là lỗi của ingress hay ở đâu?
mà kệ ko sao hihi

Rút ra kết luận Ingress nginx sẽ load balancing dựa trên các stream, để đảm bảo các connection trong 1 stream không bị gửi lộn sộn sang server khác hay là client khác.

Tiện note luôn anh compare Restful API và GRPC:

Ingress

Post navigation

Previous Post: [Golang] Convert this data type to another data type in Golang
Next Post: [Golang] Dig deeply for repository implement in Golang

More Related Articles

[GRPC/Ingress-Nginx] Add annotation for ingress-nginx to work GRPC Ingress
[ingress-nginx] Error=”ingress does not contain a valid IngressClass”, After upgrade ingress-nginx(helm 4.x.x, ingress-nginx/controller:v1.1.0) Ingress
Hướng dẫn sử dụng ingress nginx và control ingress bằng annotations trên k8s Ingress
[Cert manager] Tìm hiểu cách sử cert-manager để create ssl cho website sử dụng ingress nginx. Ingress
[Ingress Nginx/MetalLB] Install Ingress Nginx trên K8s bằng helm Ingress
[GRPC/Golang] Learning GRPC and Golang through the easy and actual lessons. Golang

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

Tham Gia Group DevOps nhé!
Để Nim có nhiều động lực ra nhiều bài viết.
Để nhận được những thông báo mới nhất.

Recent Posts

  • Protected: My Assignment  June 24, 2022
  • [Spinnaker] Spinnaker writes too many logs – Reduce spinnaker log level June 22, 2022
  • [Jenkins] Jobs will be created automatically by Jenkins Job Builder June 20, 2022
  • [Postgresql] Install postgresql client and trying a few command postgresql. June 20, 2022
  • [Mount/Nextcloud] How do you mount a hard disk that was used windows into Linux. June 19, 2022

Archives

  • June 2022
  • May 2022
  • April 2022
  • March 2022
  • February 2022
  • January 2022
  • December 2021
  • November 2021
  • October 2021
  • September 2021
  • August 2021
  • July 2021
  • June 2021

Categories

  • BareMetal
  • CI/CD
    • ArgoCD
    • ArgoWorkflows
    • Jenkins
    • Spinnaker
  • Coding
    • Git
    • Golang
    • Jquery & JavaScript
    • Laravel
    • Selenium
    • Terraform
      • AWS – Amazon Web Service
      • GCP – Google Cloud
  • Kubernetes & Container
    • Apache Kafka
      • Kafka
      • Kafka Connect
      • Lenses
    • Docker
    • Helm Chart
    • Isito-EnvoyFilter
    • Kubernetes
      • Ingress
    • Longhorn – Storage
    • Vault
    • VictoriaMetrics
  • Log & Monitor
    • ELK
      • Kibana
      • Logstash
    • Grafana
    • Prometheus
  • Uncategorized
  • Admin

Copyright © 2022 NimTechnology.