前言
负载均衡也是Nginx常⽤的⼀个功能,负载均衡其意思就是分摊到多个操作单元上进⾏执⾏,例如Web服务器、FTP服务器、企 业关键应⽤服务器和其它关键任务服务器等,从⽽共同完成⼯作任务。 简单⽽⾔就是当有2台或以上服务器时,根据规则随机的将请求分发到指定的服务器上处理,负载均衡配置⼀般都需要同时配置 反向代理,通过反向代理跳转到负载均衡。⽽Nginx⽬前⽀持⾃带3种负载均衡策略,还有2种常⽤的第三⽅策略。
一、简单配置
upstream test {
server localhost:8080;
server localhost:8081;
}
server {
listen 80; #监听端口
server_name localhost;
client_max_body_size 1024M;
location / {
proxy_pass http://test;
proxy_set_header Host $host:$server_port;
}
}
二、负载均衡访问策略
- RR(默认)每个请求按时间顺序逐⼀分配到不同的后端服务器,如果后端服务器down掉,能⾃动剔除。
权重,指定轮询⼏率,weight和访问⽐率成正⽐,⽤于后端服务器性能不均的情况。如:
upstream test {
server localhost:8080 weight=9;
server localhost:8081 weight=1;
}
ip_hash,上⾯的2种⽅式都有⼀个问题,那就是下⼀个请求来的时候请求可能分发到另外⼀个服务器,当我们的程序不是⽆状态的时候 (采⽤了session保存数据),这时候就有⼀个很⼤的很问题了,⽐如把登录信息保存到了session中,那么跳转到另外⼀台服务 器的时候就需要重新登录了,所以很多时候我们需要⼀个客⼾只访问⼀个服务器,那么就需要⽤iphash了,iphash的每个请求按 访问ip的hash结果分配,这样每个访客固定访问⼀个后端服务器,可以解决session的问题。如:
upstream test {
ip_hash;
server localhost:8080;
server localhost:8081;
}
fair(第三⽅),按后端服务器的响应时间来分配请求,响应时间短的优先分配。
upstream backend {
fair;
server localhost:8080;
server localhost:8081;
}
url_hash(第三⽅),按访问url的hash结果来分配请求,使每个url定向到同⼀个后端服务器,后端服务器为缓存时⽐较有效。在upstream中加⼊ hash语句,server语句中不能写⼊weight等其他的参数,hash_method是使⽤的hash算法
以上5种负载均衡各⾃适⽤不同情况下使⽤,所以可以根据实际情况选择使⽤哪种策略模式,不过fair和url_hash需要安装第三⽅ 模块才能使⽤,由于本⽂主要介绍Nginx能做的事情,所以Nginx安装第三⽅模块不会再本⽂介绍upstream backend {
hash $request_uri;
hash_method crc32;
server localhost:8080;
server localhost:8081;
}
总结
负载均衡的关键就是
upstream test {
server localhost:8080;
server localhost:8081;
}