当前位置:网站首页>Distributed Computing Experiment 1 Load Balancing
Distributed Computing Experiment 1 Load Balancing
2022-08-04 07:34:00 【Polaris_T】
一、实验内容
A repeat of the class the teacher demonstrates based onNginx
的负载均衡实验.
二、实验原理
1. The background of the load balancing is proposed
随着Internet的快速发展和业务量的不断提高,基于网络的数据访问流量迅速增长,Some of the data center instantaneous data traffic can be as high as dozens ofGb每秒.同时,Server site with the aid of based onHTTP,FTP,SMTPThe application of the protocol such as,为访问者提供了越来越丰富的内容和信息,This led to the huge amounts of data server gradually submerged.此外,大部分网站(尤其是电商、交通部门)All you need to provide uninterrupted24小时服务,Any service interruption or loss of critical data can cause immeasurable loss high business.这些,For application service puts forward the demand of high performance and high reliability.
然而,Relative to the rapid development of network technology,Server processor speed and memory access speed of growth is slow.The growth of network bandwidth at the same time bring the growth of the number of users,The server resource consumption made worse,Leading to the server has become a network bottleneck,The traditional stand-alone mode,Also tend to become a network fault point.
为了解决这一尴尬局面,People put forward the server load balancing strategy.
2. The meaning of load balancing and its advantages
多台服务器通过网络设备相连组成一个服务器集群,每台服务器都提供相同或相似的网络服务.服务器集群前端部署一台负载均衡设备,The load balancer is responsible for according to the configured will come from outside the network load balancing strategy of each user in the request in the Intranet server in the cluster distribution,So as to realize the multiple servers make full use of resources and rational distribution scheduling,Finally can promote efficiency of data processing and communication of distributed system.
Load balancing has several advantages:
(1) 成本较低:According to the volume configuration server,已有资源不会浪费,If you want to add resources also need not choose expensive high-end equipment;
(2) 可扩展性:当业务量增长时,系统可通过增加服务器来满足需求,且不影响已有业务,不降低服务质量;
(3) 高可靠性:单台服务器故障时,由负载均衡设备将后续业务转向其他服务器,不影响后续业务提供,保证24小时业务不中断;
(4) The client request in load balancing server cluster internal allocation,Reduced server load imbalance phenomenon happens between the probability of,To improve the response speed of the system with the overall performance.
3. The workings of a load balancing
如下图所示,Assuming that the client at a time j j jTo a web site to send a request R 1 R1 R1, R 1 R1 R1First of all, through the gateway and theInternetSent to the load balancer(According to the load balancer outside netIP);然后,The site of the load balancer USES some kind of load balancing strategy will R 1 R1 R1通过内网IPAssigned to the server in the cluster a server i i i;待服务器 i i i根据 R 1 R1 R1Passed to the parameters of the complete client j j j的请求后,服务器 i i i将客户端 j j jNeed to resource data A 1 A1 A1Passed to the load balancer;最后,The load balancer again A 1 A1 A1传递给客户端 j j j,To complete a service.
此后,When the load balancer received from a client request,Is repeated in the current load balancing strategy sends a request to the server in the cluster process requests a server to the,Finally, the corresponding resource returned to the client,By the way to make full use of all the resources of the server,Implement the load balancing server cluster,To improve the efficiency of the system process mass request data and fault tolerance ability.
4. 常用的负载均衡策略
(1) 随机;
(2) 轮询;
(3) 固定权重;
(4) IP哈希;
(5) 最少TCP连接数;
(6) 最小响应时间.
5. Nginx
Nginx
是开源、高性能、高可靠的Web和反向代理服务器,而且支持热部署,几乎可以做到7 * 24小时不间断运行,即使运行几个月也不需要重新启动,还能在不间断服务的情况下对软件版本进行热更新.性能是Nginx
最重要的考量,其占用内存少、并发能力强、能支持高达5w个并发连接数,最重要的是,Nginx
是免费的并可以商业化,配置使用也比较简单.
Nginx
的特点:
(1) 高并发、高性能;
(2) 模块化架构使得它的扩展性非常好;
(3) 异步非阻塞的事件驱动模型这点和Node.js
相似;
(4) 相对于其它服务器来说它可以连续几个月甚至更长而不需要重启服务器使得它具有高可靠性;
(5) 热部署、平滑升级;
(6) 完全开源,生态繁荣.
Nginx
的主要应用场景:
(1) 静态资源服务,通过本地文件系统提供服务;
(2) 反向代理服务,延伸出包括缓存、负载均衡等;
(3) API服务,OpenResty.
Nginx
Main configuration items to introduce:
(1) server模块:server是一切的开始,On behalf of the emergence of an agent,It includes two big configuration itemslisten(监听的端口)和server_name(监听的地址),还包括了location和其他配置项.
(2) location模块:location是Nginx
的精华,Nginx
Is by intercepting the request to the configuredlocationBlock to request broker.被代理的url去对location后边的字符串(或正则)进行匹配,According to certain rules which is your choicelocation.
(3) proxy_pass:proxy_passIs used to forward the request,Commonly used agent background services,Is to redirect the request.
(4) upstream模块:Is used to set the specific implementation of load balancing strategy andserver集群的定义,如IP、端口号、权重等等.
三、实验步骤
Step1:下载Nginx
并解压
通过http://nginx.org/en/download.html下载Nginx
,选择Stable version稳定版本:
下载完成后,将nginx-1.20.2The folder into the target path.
Step2:验证Nginx
The service can be normal boot
Enter the target pathnginx-1.20.2文件夹运行cmd,输入start nginx启动nginx
,然后在浏览器地址栏中输入localhost:80并按下回车,If the page back as shown in the figure below message,则说明nginx
服务启动成功.
Step3:用JavaScript实现服务器端
在本次实验中,我创建了5个服务器,Respectively to monitor localIP 127.0.0.1的2401, 2402, 2403, 2404, 2405端口.实现server 1的js代码如下(其余3A server implementation code display on the):
// 请求NodeJs自带的http模块,并赋值给http变量
var http = require('http');
function requestListener(request, response) {
console.log("Request received.");
// Print receipt request header
console.log(request.headers);
// 向请求的客户端发送响应头,HTTP状态码200表示请求成功
response.writeHead(200, {
"Content-Type": "text/html"});
// 输出提示信息
response.write("Hello, this is server 1.");
// 结束服务
response.end();
};
// 构造server端
// http.createServer()会返回一个对象,该对象有一个listen方法,这个方法有一个Number类型的参数,指定了HTTP服务器监听的端口号
var server = http.createServer(requestListener);
// 监听2401端口
server.listen(2401);
// The output of the server running status
console.log('Server 1 is running at http://127.0.0.1:2401... ');
After configure the server side,在js文件所在文件夹中运行cmd,输入node s1.js,运行server 1,其余四个serverThe open means of similar.
Step4:修改nginx.conf文件
1. 轮询方式:
# Configure load balancing mode as the default polling mode
upstream webservers {
server 127.0.0.1:2401;
server 127.0.0.1:2402;
server 127.0.0.1:2403;
server 127.0.0.1:2404;
server 127.0.0.1:2405;
}
server {
listen 2400;
server_name localhost;
# 设置代理转发
location / {
proxy_pass http://webservers;
}
2. 随机分发:
# Configure load balancing mode for random distribution mode
upstream webservers {
random;
server 127.0.0.1:2401;
server 127.0.0.1:2402;
server 127.0.0.1:2403;
server 127.0.0.1:2404;
server 127.0.0.1:2405;
}
3. 固定权重:
# Configure load balancing method for fixed weight way
upstream webservers {
server 127.0.0.1:2401 weight = 40;
server 127.0.0.1:2402 weight = 20;
server 127.0.0.1:2403 weight = 20;
server 127.0.0.1:2404 weight = 10;
server 127.0.0.1:2405 weight = 10;
}
4. IP Hash:
# Configure load balancing method forIP Hash方式
upstream webservers {
ip_hash;
server 127.0.0.1:2401 weight = 40;
server 127.0.0.1:2402 weight = 20;
server 127.0.0.1:2403 weight = 20;
server 127.0.0.1:2404 weight = 10;
server 127.0.0.1:2405 weight = 10;
}
5. 最少连接数:
# Configure load balancing method forIP Hash方式
upstream webservers {
least_conn;
server 127.0.0.1:2401;
server 127.0.0.1:2402;
server 127.0.0.1:2403;
server 127.0.0.1:2404;
server 127.0.0.1:2405;
}
After each update the load balance mode configuration,我们需要用nginx -s reload命令重启nginx服务.
四、实验结果
1. 轮询方式:在cmd中利用curl localhost:2400Command to access the load balancer foreign port2400,The load balancer will access request for several times in order take turns to distributeserver群中的s1,s2,s3,s4,s5.
2. 随机方式:在cmd中利用curl localhost:2400Command to access the load balancer foreign port2400,The load balancer will access request random distributed to several timesserver群中的s1,s2,s3,s4,s5.
3. Weights fixed way:在cmd中利用curl localhost:2400Command to access the load balancer foreign port2400,The load balancer will access request for several times according to the weight of each server distribution toserver群中的s1,s2,s3,s4,s5.
连续curl 20次,Statistical browser requests and distributed to allserverThe number of times shown in the following table:
server 1 | server 2 | server 3 | server 4 | server 5 |
---|---|---|---|---|
8次 | 4次 | 4次 | 2次 | 2次 |
不难看出,Browser requests by theserverThe number of received than to4 : 2 : 2 : 1 : 1,This conforms to the previously set the ratio of the weight.
4. IP Hash方式:每个请求按访问IP的HashHash result distribution,From a client request fixed access a back-end server,可以解决session的问题. 在cmd中利用curl localhost:2400Command to access the load balancer foreign port2400,Due to the local simulation requests are from the sameIP,Therefore, the load balancer will assign access request for several timesserverGroup of fixed the serverserver 1.
4. The least number of connections way:Send the request to the current link count at least backend server. 在cmd中利用curl localhost:2400Command to access the load balancer foreign port2400,Because in this experiment the server only deals with every time we usecurlSimulation of the request,There is no which server connection count more or less of a problem,So here is the least number of connections way degradation for polling mode.
4. 补充记录:
Because I'm writingserverAdd the endconsole.log(request.headers)Console, such as echo statement,因此每curl一次,相应的serverThe console will echo a request header information,如下图所示:
五、心得体会
1. 通过本次实验,I have mastered and the concept of load balancing server cluster,And through the hands-on implementation is based onNginx
和Node.js
Load balancing deepened for specific strategies include random load balancing、轮询、固定权重、IP Hash、Meet a minimum number of connections, etc.
2. In the process of the implementation of this experiment,我也遇到了一些问题,But in the end solved them,Record here some points:
(1) 在upstreamDefined in the server clusterIP时只能用127.0.0.1这个本地IP,否则无法访问,And I found that some ports have been in the experimental process takes up,无法使用,Need to select the available ports;
(2) curlThe port number must be andnginx.conf中serverBlock in the listening port number consistent,否则会请求失败;
(3) Remember that after each change of load balancing strategy withnginx -s reload命令重启nginx服务;
(4) If accidentally opened multipleNginx服务进程,可用taskkill /f /t /im nginx.exeCommand to terminate all runningnginx进程,So that we can avoid using the task manager one by onekill进程.
边栏推荐
猜你喜欢
随机推荐
七夕送礼,心愿直抵!
七夕情人节:中英文祝福短信送给你
详解CAN总线:常用CAN连接器的使用方法
力扣每日一题-第47天-15. 三数之和
Promise.all 使用方法
ERROR 2003 (HY000) Can‘t connect to MySQL server on ‘localhost3306‘ (10061)解决办法
app逆向1某联
两日总结五
TCP协议详解
反序列化字符逃逸漏洞之
FCN - the originator of semantic segmentation (based on tf-Kersa reproduction code)
MySQL - Row size too large (> 8126). Changing some columns to TEXT or BLOB
LeetCode每日五题01:两数之和 (均1200题)
中职网络安全竞赛C模块MS17-010批量扫描
登录拦截实现过程
分布式计算实验3 基于PRC的书籍信息管理系统
带你了解一下PHP搭建的电商商城系统
SQL如何从字符串截取指定字符(LEFT、MID、RIGHT三大函数)
MySQL面试题大全(陆续更新)
entity、domain、vo、pojo的区别与联系