龙空技术网

13《Nginx 入门教程》Nginx负载均衡(下)

木子教程 668

前言:

今天看官们对“nginxstream流量控制”大致比较重视,朋友们都需要分析一些“nginxstream流量控制”的相关知识。那么小编也在网络上网罗了一些对于“nginxstream流量控制””的相关资讯,希望各位老铁们能喜欢,同学们快快来了解一下吧!

这一小节中,我们将实战 Nginx 的四层和七层负载均衡功能。条件有限,使用一台公网主机,在上面搭建好 Nginx 服务。公网 IP 为 180.76.152.113。

首先会进行简单的四层负载均衡实验,不会涉及多种负载均衡算法,只使用默认的 Round-Robin算法。在后续的七层负载均衡实验中,会重点测试不同的负载均衡策略,完成相关实验。

1. Nginx的四层负载均衡实验

首先在 nginx.conf 中添加如下 stream 指令块配置:

stream {    server {        listen 3000;        return '3000 server get ip: $remote_addr!\n';    }    server {        listen 3001;        return '3001 server get ip: $remote_addr!\n';    }    upstream servers {         server 127.0.0.1:3000 weight=2;         server 127.0.0.1:3001;     }    server {        listen 30;        proxy_connect_timeout 3s;        proxy_timeout 3s;        proxy_pass servers;    }    }

上述配置用端口3000和3001模拟两个上游服务器,然后在 upstream 指令块中指定这两个上游服务器的地址,同时给第一个设置权重为2。由于默认采用的是加权的 Round-Robin 算法,默认服务器的权重为1。设置为2,表明3次请求中,2次会转发到3000端口,一次会转发到3001端口,下面的测试也验证了这一点。

# 第一次请求,转发到3000[shen@shen ~]$ telnet 180.76.152.113 30Trying 180.76.152.113...Connected to 180.76.152.113.Escape character is '^]'.3000 server get ip: 127.0.0.1!Connection closed by foreign host.[shen@shen ~]$ telnet 180.76.152.113 30Trying 180.76.152.113...Connected to 180.76.152.113.Escape character is '^]'.3001 server get ip: 127.0.0.1!Connection closed by foreign host.[shen@shen ~]$ telnet 180.76.152.113 30Trying 180.76.152.113...Connected to 180.76.152.113.Escape character is '^]'.3000 server get ip: 127.0.0.1!Connection closed by foreign host.[shen@shen ~]$ telnet 180.76.152.113 30Trying 180.76.152.113...Connected to 180.76.152.113.Escape character is '^]'.3000 server get ip: 127.0.0.1!Connection closed by foreign host.
2. Nginx的七层负载均衡实验

和四层的配置其实差不多,在七层中除了测试最基本的,我们还将测试前面提到的几种负载均衡策略,进一步熟悉 Nginx 中的负载均衡配置。

2.1 简单的七层负载均衡

在 nginx.conf 中添加如下的 http 指令块:

http {    include       mime.types;    default_type  application/octet-stream;    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '                      '$status $body_bytes_sent "$http_referer" '                      '"$http_user_agent" "$http_x_forwarded_for"';    access_log  logs/access.log  main;    sendfile        on;    keepalive_timeout  65;    gzip  on;    server {        listen 8000;        return 200 '8000, server\n';    }    server {        listen 8001;        return 200 '8001, server\n';    }    server {        listen 8002;        return 200 '8002, server\n';    }      upstream backends {        # ip_hash        # hash user_$arg_username;        server 127.0.0.1:8000;        server 127.0.0.1:8001;        server 127.0.0.1:8002;    }      server {       listen  80;       location / {          proxy_pass ;          proxy_http_version 1.1;          proxy_set_header Connection "";       }    }}

上述配置中,我们用8000,8001和8002三个端口模拟了3个上游服务器,默认使用轮询负载均衡算法,而且三个的权重均为1。进行如下的 http 请求操作,可以看到 Nginx 转发 http 请求会均匀地分配到3个服务器上。

[shen@shen ~]$ curl , server[shen@shen ~]$ curl , server[shen@shen ~]$ curl , server[shen@shen ~]$ curl , server
2.2 负载均衡的hash算法

我们打开 ip_hash 指令的注释,这个时候默认是使用客户端的 ip 地址作为 hash 的 key,然后重启 Nginx 服务并进行如下的命令行操作:

# 使用本机的ip地址,无论请求多少出,通过hash转发到的上游服务器地址都是一致的[shen@shen ~]$ curl , server[shen@shen ~]$ curl , server[shen@shen ~]$ curl , server# 只有换了ip之后,请求转发的上游地址才可能有变化[shen@shen ~]$ curl -H 'X-Forwarded-For: 111.10.1.3' , server[shen@shen ~]$ curl -H 'X-Forwarded-For: 111.10.2.3' , server
2.3 使用其他key做hash

接下来,注释 ip_hash 指令,我们打开 hash user_$arg_username 这行配置的注释, hash 指令可以让我们根据我们设置的 key 进行 hash,然后根据 hash 值选择上游的服务器。具体测试参看下面的 Linux 命令:

[shen@shen ~]$ curl , server[shen@shen ~]$ curl , server[shen@shen ~]$ curl , server[shen@shen ~]$ curl , server

这里我们可以看到,在请求中带上 username 参数,Nginx 中配置的 hash 算法会根据请求中带的 username 参数作为 key 去进行 hash,然后在根据 hash 结果映射上游服务器。username 相同时,选择的上游服务器肯定是一样的,只有在 username 的值发生变化时,返回的响应才可能有变化。

3. 小结

今天我们完成了几个测试实验,主要是针对 Nginx 的四层和七层的负载均衡功能进行了测试。这个功能在微服务部署中会有较多的应用。因为高流量企业为保证服务的高可用性,往往会水平扩展多个相同功能的服务,部署在多台主机上,这个时候负载均衡技术就能派上用场了,而 Nginx 提供了完善的负载均衡功能以及多种负载均衡算法,能满足大部分企业的需求,如果还不够,可以通过编写内部开发模块并集成到 Nginx,实现相应的需求。所以说 Nginx 是非常值得学习和深入研究的。

标签: #nginxstream流量控制