Analyzing Kubernetes gRPC load balancing (L4 vs L7)
This article is introduced by the go language tutorial column to introduce gRPC load balancing in Kubernetes. I hope it will be helpful to friends in need!
Installation environment dependencies
- docker-desktop >= 4.1.1
- kubernetes >= 1.21.5
- go >= 1.17
- protobuf >= 3.17.3
- istioctl >= 1.11.4
Download and install Docker Desktop and start the built-in Kubernetes cluster.
# 安装 Gobrew install go# 安装 Protobufbrew install protobuf# 安装 Istiobrew install istioctl kubectl config use-context docker-desktop istioctl install -y
Project address
github.com/jxlwqq/grpc-lb
Pull code:
git clone git@github.com:jxlwqq/grpc-lb.gitcd grpc-lb
Makefile Introduction
Command | Description |
---|---|
##make init
| Install protoc-gen-go and protoc-gen-grpc|
make protoc
| Based on proto File, generate *_pb.go and *_grpc.pb.go|
make docker-build
| Build docker image|
make kube-deploy
| Deploy services in the cluster|
Delete service |
|
Inject Istio sidecar |
L4 vs L7 Load BalancingThe so-called layer four is load balancing based on IP ports, while layer seven is load balancing based on application layer information such as URLs; Kubernetes The built-in Service load balancing is based on iptables/ipvs and only supports L4. In other words, Service supports the HTTP/1.1 protocol but does not support the HTTP/2 protocol.
Envoy (Istio) is more versatile and supports all HTTP/2 functions requested and responded by gRPC as the underlying routing and load balancing.
Project ArchitectureThis project tests the support of Service and Envoy (Istio) for HTTP/RPC load balancing respectively.
cmd/server/main.go: Server, providing both HTTP and RPC services. The response data is the Pod name where the server container is located (based on Downward API).- cmd/client-http/main.go: HTTP client, through HTTP mode, calls the server interface cyclically and prints the return value.
- cmd/client-grpc/main.go: The gRPC client, through RPC, calls the server method remotely in a loop and prints the return value.
Testing PrincipleThe server deploys 3 copies in the Kubernetes cluster in the form of Deployment. The Pod names of the 3 copies are different, and client-http and client-grpc will call the server once every second and print the return value. If all three Pod names exist in the return value, it indicates that effective load balancing is being performed; otherwise, it indicates that effective load balancing is not being performed.
Test ServiceBuild the image:
make docker-build # 构建镜像(构建好的镜像,不 push 到远程仓库中)
View the image:
docker images ls
Return:
REPOSITORY TAG IMAGE ID CREATED SIZE grpc-lb/client-grpc latest 95d32ead8d9b 12 seconds ago 16.6MB grpc-lb/client-http latest dbf0341206f6 22 seconds ago 11.5MB grpc-lb/server latest 1ef346785b2a 29 seconds ago 18.2MB
Deployment Go to the cluster:
make kube-deploy # 在集群中部署服务
View Pod:
kubectl get pods
Return:
NAME READY STATUS RESTARTS AGE client-grpc-6c565594f4-tdf75 1/1 Running 0 2m48s client-http-55d95c744d-f7nx4 1/1 Running 0 2m49s server-7c4bfd74d-29c69 1/1 Running 0 2m51s server-7c4bfd74d-4btvw 1/1 Running 0 2m51s server-7c4bfd74d-fk8zf 1/1 Running 0 2m51s
View the log of client-http Pod:
export CLIENT_HTTP_POD=$(kubectl get pod -l app=client-http -o jsonpath={.items..metadata.name})kubectl logs "${CLIENT_HTTP_POD}"
Return:
#1: server-7c4bfd74d-4btvw#2: server-7c4bfd74d-4btvw#3: server-7c4bfd74d-29c69#4: server-7c4bfd74d-fk8zf#5: server-7c4bfd74d-fk8zf#6: server-7c4bfd74d-29c69#7: server-7c4bfd74d-fk8zf#8: server-7c4bfd74d-4btvw#9: server-7c4bfd74d-fk8zf
View the log of client-grpc Pod:
export CLIENT_GRPC_POD=$(kubectl get pod -l app=client-grpc -o jsonpath={.items..metadata.name})kubectl logs "${CLIENT_GRPC_POD}"
Return:
#1: server-7c4bfd74d-fk8zf#2: server-7c4bfd74d-fk8zf#3: server-7c4bfd74d-fk8zf#4: server-7c4bfd74d-fk8zf#5: server-7c4bfd74d-fk8zf#6: server-7c4bfd74d-fk8zf#7: server-7c4bfd74d-fk8zf#8: server-7c4bfd74d-fk8zf#9: server-7c4bfd74d-fk8zf
It can be seen that the HTTP request is carrying a payload, while the RPC request is carrying an invalid load.
Test Envoy(Istio)We have deployed an Istio in the cluster, but there is no command space for automatic injection, so we perform manual injection here.
Manual injection:
make istio-inject # 注入 Istio 边车
View Pod:
kubectl get pods
Return:
NAME READY STATUS RESTARTS AGE client-grpc-7864f57779-f6blx 2/2 Running 0 17s client-http-f8964854c-jclkd 2/2 Running 0 21s server-7846bd6bb4-bcfws 2/2 Running 0 27s server-7846bd6bb4-fv29s 2/2 Running 0 40s server-7846bd6bb4-hzqj6 2/2 Running 0 34s
View the log of client-http Pod:
export CLIENT_HTTP_POD=$(kubectl get pod -l app=client-http -o jsonpath={.items..metadata.name})kubectl logs "${CLIENT_HTTP_POD}"
Return:
#1: server-7846bd6bb4-hzqj6#2: server-7846bd6bb4-fv29s#3: server-7846bd6bb4-hzqj6#4: server-7846bd6bb4-hzqj6#5: server-7846bd6bb4-hzqj6#6: server-7846bd6bb4-hzqj6#7: server-7846bd6bb4-hzqj6#8: server-7846bd6bb4-bcfws#9: server-7846bd6bb4-fv29s
View the log of client-grpc Pod:
export CLIENT_GRPC_POD=$(kubectl get pod -l app=client-grpc -o jsonpath={.items..metadata.name})kubectl logs "${CLIENT_GRPC_POD}"
Return:
#1: server-7846bd6bb4-fv29s#2: server-7846bd6bb4-hzqj6#3: server-7846bd6bb4-fv29s#4: server-7846bd6bb4-bcfws#5: server-7846bd6bb4-fv29s#6: server-7846bd6bb4-hzqj6#7: server-7846bd6bb4-fv29s#8: server-7846bd6bb4-bcfws#9: server-7846bd6bb4-fv29s
It can be seen that both HTTP requests and RPC requests are carrying payloads.
Cleanupmake kube-delete
istioctl experimental uninstall --purge
Copy after login
make kube-delete istioctl experimental uninstall --purge
The above is the detailed content of Analyzing Kubernetes gRPC load balancing (L4 vs L7). For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

How to implement file upload using gRPC? Create supporting service definitions, including request and response messages. On the client, the file to be uploaded is opened and split into chunks, then streamed to the server via a gRPC stream. On the server side, file chunks are received and stored into a file. The server sends a response after the file upload is completed to indicate whether the upload was successful.

Best practices for using gRPC to implement concurrent data transmission in Golang Introduction: With the development of cloud computing and big data technology, the demand for data transmission is becoming more and more urgent. As Google's open source high-performance remote procedure call framework, gRPC has become the first choice of many developers because of its efficiency, flexibility and cross-language features. This article will introduce the best practices on how to use gRPC to implement concurrent data transmission in Golang, including the construction of project structure, the use of connection pools and error handling, etc. 1. Building the engineering structure at the beginning

As the scale of the Internet continues to expand and user needs continue to increase, the advantages of microservice architecture are receiving more and more attention. Subsequently, the containerized microservice architecture has become particularly important, which can better meet the needs of high availability, high performance, high scalability and other aspects. Under this trend, go-zero and Kubernetes have become the most popular containerized microservice frameworks. This article will introduce how to use the go-zero framework and Kubernetes container orchestration tools to build high-availability, high-performance

In modern network applications, handling high concurrency is a very important issue. In this process, using gRPC can be a great way to achieve efficient client-server communication through remote procedure calls (RPC). In PHP applications, we can use gRPC to handle high concurrent API requests. This article will introduce how to use gRPC to handle high-concurrency APIs in PHP. What is gRPC? gRPC is a high-performance RPC framework developed by Google. it

With the rapid development of the Internet, more and more enterprises have begun to migrate their applications to cloud platforms. Docker and Kubernetes have become two very popular and powerful tools for application deployment and management on cloud platforms. Beego is a web framework developed using Golang. It provides rich functions such as HTTP routing, MVC layering, logging, configuration management, Session management, etc. In this article we will cover how to use Docker and Kub

How to use Java to develop a container orchestration application based on Spring Cloud Kubernetes. With the development and widespread application of container technology, container orchestration tools have become an indispensable part of developers. As one of the most popular container orchestration tools, Kubernetes has become the industry standard. In this context, combining Spring Cloud and Kubernetes, we can easily develop applications based on container orchestration. This article will introduce in detail

Best practices for using gRPC to implement data encryption in Golang Introduction: In today's era when information security is highly valued, protecting the security of data has become more and more important. In distributed systems, how to ensure the security of data during network transmission is an issue that must be paid attention to. gRPC is a high-performance, cross-language remote procedure call framework that provides higher data security by using ProtocolBuffers for data serialization and transmission, and supports TLS/SSL encrypted transmission.

How to build reliable containerized applications using React and Kubernetes With the rapid development of cloud native technology, containerized applications have become a hot trend in software development today. As a popular front-end framework, React's flexibility and efficiency make it the first choice for many developers. This article will introduce how to build reliable containerized applications using React and Kubernetes, and provide some specific code examples. Creating a React application First, we need to create a basic React
