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

问题

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

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

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

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

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

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

解析

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

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

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

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

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

参考答案

ABC

相关推荐
睡不醒的猪儿13 小时前
Nginx 服务优化与防盗链配置方案
运维·nginx
大佐不会说日语~13 小时前
使用 Cloudflare平台 + Docker + Nginx 完成网站 HTTPS 部署实战记录
nginx·docker·https·部署·cloudflare
Knight_AL13 小时前
使用 Nginx 为内网 Java 服务实现 HTTPS
java·nginx·https
坚持学习前端日记14 小时前
Nginx 搭建文件服务器
运维·服务器·nginx
徐同保15 小时前
nginx接口超时,增加接口超时时间
运维·nginx
Benny的老巢1 天前
Mac上用XAMPP搭建局域网可访问的开发环境,让局域网内其他设备通过域名访问
nginx·macos·apache·xampp·php开发环境
岚天start1 天前
Docker部署NGINX实现服务四层转发方案
服务器·nginx·docker
云飞云共享云桌面1 天前
非标自动化工厂的设计云桌面为什么要选云飞云智能共享云桌面?
大数据·运维·服务器·网络·自动化·负载均衡
微凉的衣柜1 天前
Windows Server 使用 Nginx 反向代理实现域名访问内网 Gradio 应用
运维·windows·nginx
上去我就QWER1 天前
什么是反向代理?
后端·nginx