面试刷题35:负载均衡有哪几种实现方式?
off999 2025-04-11 04:43 62 浏览 0 评论
今天的问题是:负载均衡是为了解决什么问题?有哪几种实现负载均衡的方式?
解决的问题
把用户的请求分发到多台服务器(更多的资源),解决高并发的问题。
硬件负载均衡
成本比较高,并发数在百万级别,比如F5;
软件负载均衡
HTTP重定向负载均衡
负载均衡过程如上图:
1 请求到负载均衡服务器,
2 根据均衡算法,返回304,重定向到实际负责计算的服务器ip到浏览器,
3 然后浏览器直接请求实际负责计算的服务器,
4 最后实际计算的服务器响应到客户端浏览器。
缺点:
1,请求经过两次服务器(负载均衡服务器,实际计算服务器),增加了响应时间。
2,暴露了实际负载的服务器公网ip到浏览器,安全性比较低。
java代码实现:
response.sendRedirct("http://ip/xxxService?parama=a");DNS负载均衡
负载均衡过程如上图:
1, 用户请求域名,请求到DNS服务器;
2,DNS服务返回解析的IP地址到客户端;并不暴露到浏览器进行重定向;
3,客户端拿到返回的负责计算的服务器IP,请求服务器;
4,计算服务器返回响应信息;
改进:
1,不用每次都请求负载的ip,可以缓存起来,重复使用,提高性能;
2,dns不用暴露实际计算的服务器ip(不是采用重定向的方式暴露在浏览器,而且做了二次负载均衡,内网的IP不会暴露出来),安全性略好;
异地多活采用的这种方式,一个ip解析到不同区域的IP,实现第一层级的负载均衡,然后基于区域ip做二级的负载均衡;
反向代理负载均衡
负载均衡过程如下:
1,客户端发起请求到负载均衡服务器,负载均衡服务器根据算法得到负载的IP;
2,负载均衡服务器构造请求,请求内网负载的计算服务器;
3, 计算服务器返回响应结果到负载均衡服务器;
4,负载均衡服务器返回响应结果给到客户端。
比如nginx, apache
缺点:基于http层做的负载均衡,是一个比较重的协议,效率略低;
一般适用于比较小的集群,10+规模;
IP层的负载均衡
对网络层的IP地址进行替换,不需要在http层工作,直接在操作系统内核的IP数据包中替换地址。效率比基于HTTP层的反向代理高。 负载均衡过程:
1,客户端请求负载均衡服务器;
2,负载均衡服务器修改目的ip为内网机器的IP ;
3, 内网机器计算完毕,响应的IP改为负载均衡服务器ip的内网地址;
4,负载均衡服务器修改响应的IP为自己的外网IP ,返回结果给到客户端;
缺点:
请求和响应度需要经过负载均衡服务器进行ip层替换,响应数据会成为后期的瓶颈。
数据链路层负载均衡
解决响应数据体量过大效率低的问题。 通过修改数据链路层的mac地址,ip使用的是虚拟IP,来实现负载均衡。
负载均衡过程:
1,客户端请求负载均衡服务器;
2,负载均衡服务器替换mac地址为计算服务器,Ip为负载均衡服务器ip;
3, 计算服务器直接响应数据到客户端;
这种负载均衡方式吞吐量最高,大型互联网公司都是采用这种负载均衡方式。
LVS负载均衡是结合了IP层和数据链路层的负载均衡方式。linux通过配置可以实现这两种负载均衡方式。
小结
本篇从负载均衡出发的目的出发,即为了应对高并发,把请求分摊到更多的服务器上。
从简单到复杂,依次介绍了HTTP重定向实现负载均衡,DNS实现负载均衡,
反向代理实现负载均衡,IP层实现负载均衡,数据链路层实现负载均衡。
一图胜千言,给出了负载均衡的过程。
一般常用的是DNS和数据链路层负载均衡。
我会持续分享Java软件编程知识和程序员发展职业之路,欢迎关注! 原创不易,点赞关注支持一下吧!转载请注明出处,让我们互通有无,共同进步,欢迎沟通交流。
相关推荐
- c盘右边有个恢复分区怎么删除
-
1、从网上下载“分区助手专业6.2(或5.6)”,它能无损分区,下载后打开按提示安装,点击分区助手桌面快捷方式图标,打开分区助手专业版6.2主界面。2、右击要调出空间的分区,如E,选“分配自由空间”,...
- 电脑插着电源却不充电怎么办
-
电脑插上电源但无法充电可能有以下原因:1.电池没有完全安装,需要检查电池是否完全插入笔记本电脑中。2.电池损坏,如果电池老化或发生机械故障、磨损和损伤,充电电流将会被阻塞从而无法进行充电,需要更换...
-
- 如何格式化手机(华为p50如何格式化手机)
-
步骤/方式1软件格式化:利用psiloc公司的软件sTools,进行格式化手机,锁码为12345步骤/方式2软格:在手机上输入*#7370#之后要求你输入锁码,初始密码是:12345步骤/方式3硬格:先关机,再开机的时候按住拨号键、“*...
-
2025-12-17 12:03 off999
- win10自动更新的禁用方法(win10自动更新的禁用方法是什么)
-
方法一:Windows设置 要想关闭Win10自动更新,比较简单的一种方法就是进入到Windows设置中,将Windows更新直接关闭。步骤如下: 1、按“Windows+I”键,打开Wind...
- 优化win7系统运行速度(优化win7系统运行速度多少)
-
优化WIN7系统开机启动项的操作方法1、在桌面上按组合键(win键+R)打开运行窗口,接着输入“regedit”,回车确认,2、打开注册表编辑器后,我们依次点击展开“HKEY_CURRENT_USE...
- win7设置每天自动开机时间(win7设置每天自动开机时间任务)
-
要在Windows7上设置每天自动开关机,您可以按照以下步骤操作:1.打开“控制面板”,单击“系统和安全”,然后选择“计划任务”。2.单击“创建基本任务”,输入一个适合您的任务名称,并添加相应的...
- 苹果电脑装双系统好用吗(苹果电脑安装双系统会不会对电脑不好)
-
好处:1、可以在保留原来的系统上再安装一个新系统,两个系统互不干扰,可以互相切换,使用方便。2、双系统可以在不用环境系进行软件调试没测试电脑的兼容性。3、双系统可以让用户体验不同的系统功能,提高用户的...
- 在电脑上复制粘贴按什么键(电脑怎复制粘贴按那个键)
-
电脑键盘上的“复制和粘贴”,分别是Ctrl+c和Ctrl+v,其中复制的快捷键是Ctrl+c,粘贴的快捷键是Ctrl+v。鼠标右键,点击右键会出菜单,移动光标后点击左键确认。键盘复制的快捷键:Ctrl...
- office是电脑自带的吗(电脑自带的office都是2016版)
-
基本上大品牌电脑,都会带正版的office软件。如果是自己组装的电脑,一般使用的盗版软件,不是正版的。现在office软件分为国产和进口两个版本,进口的是微软office,国产的是wpsoffice...
- appstore应用商店下载(AppStore应用商店下载入口)
-
可能因为1.你的软件原来在其他国家下载的,你现在账户不支持那个软件的更新,只要更改到相应的地区就好了2.可能你网不好(?˙ー˙?)3.你的pad原来登录的账户和现在不一样,所以你现在...
- 联想售后人工客服24小时电话
-
联想服务中心朝阳区望京店距您12.2KM营业时间:周一至周日9:00-18:00疫情期间停业好评度:98%已服务人数61945联想服务中心昌平区天通苑店距您5.1KM营业时间:周一至周日9:...
- 鼠标dpi键有什么作用(鼠标的dpi键)
-
鼠标DPI(DotsPerInch)键的作用是调节鼠标的定位精度和速度。DPI是鼠标的定位精度单位,指的是鼠标在平面上每移动一英寸能准确定位的最大信息数。通常情况下,鼠标DPI越高,鼠标指针在屏幕...
- 无线网登录密码忘记了怎么办
-
1、先查看一下wifi链接的网关是多少,如果是默认的多为192.168.1.1或者192.168.0.1这个地址。2、然后打开ie浏览器,输入查看到的网关地址,比如192.168.1.1,会弹出登录对...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
使用 python-fire 快速构建 CLI_如何搭建python项目架构
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
