实现原理
Nginx使用proxy_pass,把请求转发到后端一组服务池(upstream server)上,根据相关负载均衡规则来指定一台提供服务的服务端进行请求的处理。
一、基本语法配置
#upstream server
语法:upstream name{ ... }
默认值:无
上下文:http
如:
upstream backend {
server backend1.example.com weight=5; #weight轮询权重
server backend2.example.com:8080;
server unix:/tmp/backend3;
server backup1.example.com:8080 backup; #备份节点
server backup2.example.com:8080 backup; #备份节点
}
简单用例
#轮询负载均衡
upstream backend {
server 127.0.0.1:8001;
server 127.0.0.1:8002;
server 127.0.0.1:8003;
}
server {
listen 80;
server_name localhost www.sam.com;
#charset koi8-r;
#access_log /var/log/nginx/host.access.log main;
location / {
proxy_pass http://backend;
#当命中的服务器出现错误、超时、请求头不完整、500、502、503时,会跳过这一台服务器去访问下一台服务器。
proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
proxy_redirect default; #一般配置默认即可
#添加头信息
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
#配置超时
proxy_connect_timeout 30;
proxy_send_timeout 60;
proxy_read_timeout 60;
#配置缓冲区,
proxy_buffer_size 32k;
proxy_buffering on;
proxy_buffers 4 128k;
proxy_busy_buffers_size 256k;
proxy_max_temp_file_size 256k;
}
#error_page 404 /404.html;
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/html;
}
}
二、后端服务器在负载均衡调度中的状态
down 当前的server暂时不参与负载均衡
backup 预留的备份服务器
max_fails 允许请求失败的次数
fail_timeout 经过max_fails失败后,服务暂停的时间
max_conns 限制最大的接收的连接数
例子
upstream backend {
server 127.0.0.1:8001 down; #不提供服务
server 127.0.0.1:8002 backup; #备份服务,如果8003挂了 将会提供服务
server 127.0.0.1:8003 max_fails=1 fail_timeout=10s;
}
三、负载均衡策略 - 调度算法
轮询 按时间顺序逐一分配到不同的后端服务器
加权轮询 weight值越大,分配到的访问几率越高
ip_hash 每个请求按访问IP的hash结果分配,这样来自同一个IP的固定访问同一个后端服务器
url_hash 按照访问的URL的hash结果来分配请求,是每个URL定向到同一个后端服务器,通过hash关键数值实现
least_conn 最少连接数,哪个机器连接数少就分配到哪个机器
hash关键数值 hash自定义的key
1、轮询与加权轮询
#轮询与加权轮询
#理论上:当有7个请求过来的时候,将会有5个请求命中8002机器
upstream backend {
server 127.0.0.1:8001;
server 127.0.0.1:8002 weight=5; #5权重
server 127.0.0.1:8003;
}
2、ip_hash基于ip的hash值实现负载均衡
#每个请求按访问IP的hash结果分配,这样来自同一个IP的固定访问同一个后端服务器
upstream backend {
ip_hash;
server 127.0.0.1:8001;
server 127.0.0.1:8002;
server 127.0.0.1:8003;
}
3、url_hash基于url的hash值实现负载均衡
#按照访问的URL的hash结果来分配请求,是每个URL定向到同一个后端服务器
upstream backend {
hash $request_uri; #请求参数,如 http://www.sam.com/index.html 中的 /index.html
server 127.0.0.1:8001;
server 127.0.0.1:8002;
server 127.0.0.1:8003;
}