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
    • MetalLB
    • Kong Gateway
  • CI/CD
    • ArgoCD
    • ArgoWorkflows
    • Spinnaker
    • Jenkins
    • Harbor
    • TeamCity
    • Git
      • Bitbucket
  • Coding
    • Terraform
      • GCP – Google Cloud
      • AWS – Amazon Web Service
    • Golang
    • Laravel
    • Python
    • Jquery & JavaScript
    • Selenium
  • Log & Monitor
    • DataDog
    • Prometheus
    • Grafana
    • ELK
      • Kibana
      • Logstash
  • BareMetal
    • NextCloud
  • 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

[Ingress Nginx] Internal error occurred: failed calling webhook “validate.nginx.ingress.kubernetes.io” Ingress
[ingress-nginx] ingress /contains invalid path 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
[Metallb] Create LoadBalancer Service on K8S (on-premise) so easily Ingress
[GRPC/Golang] Learning GRPC and Golang through the easy and actual lessons. Golang
[Ingress Nginx/MetalLB] Install Ingress Nginx trên K8s bằng helm Ingress

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

  • Experiences for IP Addresses Shortage on EKS Clusters March 29, 2023
  • [Talisman] Discover the sensitive information in your code. March 28, 2023
  • [Prometheus/Grafana] Install Prometheus and Grafana on ubuntu. March 27, 2023
  • [Kong Gateway] WebSocket connection failed March 26, 2023
  • [Nextcloud] Can’t download files to have a size bigger than 2Gi on NextCloud – RaspBerry March 24, 2023

Archives

  • March 2023
  • February 2023
  • January 2023
  • December 2022
  • November 2022
  • October 2022
  • September 2022
  • August 2022
  • July 2022
  • 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
    • NextCloud
  • CI/CD
    • ArgoCD
    • ArgoWorkflows
    • Git
      • Bitbucket
    • Harbor
    • Jenkins
    • Spinnaker
    • TeamCity
  • Coding
    • Golang
    • Jquery & JavaScript
    • Laravel
    • Python
    • Selenium
    • Terraform
      • AWS – Amazon Web Service
      • GCP – Google Cloud
  • Kubernetes & Container
    • Apache Kafka
      • Kafka
      • Kafka Connect
      • Lenses
    • Docker
    • Helm Chart
    • Isito-EnvoyFilter
    • Kong Gateway
    • Kubernetes
      • Ingress
    • Longhorn – Storage
    • MetalLB
    • Vault
    • VictoriaMetrics
  • Log & Monitor
    • DataDog
    • ELK
      • Kibana
      • Logstash
    • Grafana
    • Prometheus
  • Uncategorized
  • Admin

Copyright © 2023 NimTechnology.