Nginx在web应用的部署中,作为一种轻量级的负载均衡服务器,起到很强大的作用,其中的常见5种负载均衡的模式也是我们最常用的,下面给大家介绍一下相关的配置。
Nginx负载的5种策略设置方法:
- 轮询(默认)
- 指定权重
- IP绑定 ip_hash
- fair
- url_hash
1、轮询(默认)
每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
轮询:nginx默认就是轮询其权重都默认为1,服务器处理请求的顺序:ABABABABAB…
#自定义服务名
upstream tomcat_server{
server 127.0.0.1:1234;
server 127.0.0.1:8769;
}
server {
listen 80;
server_name localhost;
location / {
proxy_pass http://tomcat_server;
proxy_set_header Host $host; #配置端口,否则可能访问失败
}
2、指定权重
指定轮询几率,weight权重大小和访问比率成正比,用于后端服务器性能不均的情况。
加权轮询:跟据配置的权重的大小而分发给不同服务器不同数量的请求。如不设置,则默认1。下面服务器的请求顺序为:ABBABBABBABBABB…
#自定义服务名
upstream tomcat_server{
server 127.0.0.1:1234 weight=1;
server 127.0.0.1:8769 weight=2;
}
server {
listen 80;
server_name localhost;
location / {
proxy_pass http://tomcat_server;
proxy_set_header Host $host; #配置端口,否则可能访问失败
}
3、ip_hash
ip_hash: nginx会让相同的客户端ip请求相同的服务器。每个请求,按访问ip的hash结果进行分配,这样每个访客,会固定访问同一个后端服务器,可以解决session的问题。
#自定义服务名
upstream tomcat_server{
ip_hash;
server 127.0.0.1:1234;
server 127.0.0.1:8769;
}
server {
listen 80;
server_name localhost;
location / {
proxy_pass http://tomcat_server;
proxy_set_header Host $host; #配置端口,否则可能访问失败
}
4、fair
按后端服务器的响应时间来分配请求,响应时间短的优先分配。
#自定义服务名
upstream backserver {
server server1;
server server2;
fair;
}
server {
listen 80;
server_name localhost;
location / {
proxy_pass http://tomcat_server;
proxy_set_header Host $host; #配置端口,否则可能访问失败
}
5、url_hash
按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。
#自定义服务名
upstream backserver {
server squid1:3128;
server squid2:3128;
hash $request_uri;
hash_method crc32;
}
server {
listen 80;
server_name localhost;
location / {
proxy_pass http://tomcat_server;
proxy_set_header Host $host; #配置端口,否则可能访问失败
}