架构师面试(二十三):负载均衡

问题

今天我们聊微服务相关的话题。

大中型微服务系统中,【负载均衡】是一个非常核心的组件;在微服务系统的不同位置对【负载均衡】进行了实现,下面说法正确的有哪几项?

A. LVS 的负载均衡一般通过前置 F5 或是通过 VIP + keepalive 实现;

B. Nginx 的负载均衡一般通过前置 LVS 或是 VIP + keepalive 实现;

C. 服务的负载均衡一般通过上游服务的 RPC 连接池实现;

D. 存储的负载均衡一般上游服务的 存储 连接池实现。

解析

在集群模式的系统中,【负载均衡】是一个非常非常关键的核心组件,它按一定的比例将流量转发到集群中的节点上,使集群中的节点按照均衡的负载稳定运行;除了管理负载,【负载均衡】组件也可以实现 集群的 高可用、高并发和高扩展。

在微服务系统中,每一分层集群的负载均衡,通常是基于上一层的负载均衡组件实现的,比如:数据访问层集群的负载均衡一般通过业务逻辑层节点的 RPC 连接池实现、业务逻辑层集群的负载均衡一般通过网关层节点的 RPC 连接池实现、网关层集群的负载均衡一般通过反向代理实现; 这样层层向上,终有头,到头了怎么处理呢? 通常通过 VIP + keepalive 的方式实现。

总结:微服务系统中,负载均衡的实现,有两种常用方式,即 前置组件 和 VIP + keepalive。

需要注意,存储层部分比较复杂,大量的数据需要【分片 + 副本】,要保证存储集群节点的负载均衡性,既需要考虑写负载、也要考虑读负载,既需要考虑分片后的路由,也要考虑分片副本的可用性;所以对于存储系统的负载均衡往往由其内部组件负责,比如 TiDB、Codis、RocketMQ 等。 (所以 D 选项是错误的)

这一部分内容我们在【架构师】课程的【架构篇之整体架构分析】中讲过哈,听过的同学好好复习一下,没有听过的同学当做一次知识输入。

参考答案

ABC

相关推荐
larance4 小时前
Gunicorn + Nginx+systemd 配置flask
nginx·flask·gunicorn
文艺理科生Owen6 小时前
Nginx 路径映射深度解析:从本地开发到生产交付的底层哲学
运维·nginx
kong790692811 小时前
Nginx性能优化
java·nginx·性能优化
匀泪12 小时前
云原生(LVS DR模式ipvs实验)
服务器·网络·lvs
瑶山12 小时前
Spring Cloud微服务搭建五、集成负载均衡,远程调用,熔断降级
spring cloud·微服务·负载均衡·远程调用·熔断降级
主机哥哥1 天前
阿里云OpenClaw部署全攻略,五种方案助你快速部署!
服务器·阿里云·负载均衡
Harvey9031 天前
通过 Helm 部署 Nginx 应用的完整标准化步骤
linux·运维·nginx·k8s
全栈工程师修炼指南1 天前
Nginx | stream content 阶段:UDP 协议四层反向代理浅析与实践
运维·网络·网络协议·nginx·udp
鹏北海1 天前
micro-app 微前端项目部署指南
前端·nginx·微服务
全栈工程师修炼指南1 天前
Nginx | stream content 阶段:TCP 协议四层反向代理浅析与实践
运维·网络·网络协议·tcp/ip·nginx