负载均衡是nginx的一个重要的功能,在高并发的系统下,需要采用集群或是分布式的服务进行部署,nginx的负载均衡就是将客户端的请求分摊到各个操作单元机器上
负载方式:
1、轮询(默认)
upstream www_servers{
server localhost:8081;
server localhost:8082;
}
server {
listen 80;
server_name localhost;
#access_log logs/host.access.log main;
location / {
proxy_pass http://www_servers;
# 必须指定Header Host
proxy_set_header Host $host:$server_port;
}
}
2、权重
weight越大 权重越高
upstream www_servers{
server localhost:8081 weight=1;
server localhost:8082 weight=2;
server localhost:8083 weight=4 backup;
}
假如3次请求 8081 1次,8082 2次
backup是指热备,只有当8081和8082都宕机的情况下才走8083。
3、ip_hash
大家都知道当我们的服务不是无状态的,采用session保存数据比如登录信息,那么如果采用轮询的话那么轮询到一台新的服务器的话,那么就找不到对应session了,所以ip_hash就是让一个客户之访问一个服务器,那么就要用ip_hash,每个请求都是按照ip的hash结果分配
upstream www_servers{
ip_hash;
server localhost:8080;
server localhost:8081;
}
4、fair
按后端服务器的响应时间来分配请求,响应时间短的优先分配。这个配置是为了更快的给用户响应。
upstream www_servers{
fair;
server localhost:8080;
server localhost:8081;
}
5、url hash
按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。在upstream中加入hash语句,server语句中不能写入weight等其他的参数,hash_method是使用的hash算法。
upstream www_servers{
hash $request_uri;
hash_method crc32;
server localhost:8080;
server localhost:8081;
}
以上5种负载均衡最常用的还是第一二三种,也可以根据实际情况选择使用哪种策略模式,不过fair和url_hash需要安装第三方模块才能使用。