Nginx的负载均衡

1.upstream模块

upstream模块介绍
Nginx的负载均衡功能依赖于ngx_http_upstream_module,所支持的代理方式有proxy_pass,fastcgi_pass,memcached_pass。
upstream模块例子:

 upstream web_pools{
   server 172.16.10.52:80 weight=1;
   server 172.16.10.53:80 weight=3;
 }

upstream模块应该放于http{}标签内
默认算法是wrr轮询
upstream内部参数说明:

参数 说明
server 172.16.10.52:80 server后面接需要代理的主机,可以不接端口号,默认是80
weight 权重
backup 当所用的RS失效后会启用它
max_fails=2 最大失败尝试次数,建议2-3次
fail_timeout=20 失败超时时间,默认是10s,常规业务一般设置为2-3秒
down 表示服务不可用,一般配合ip_hash一起使用。
max_conns=number 最大连接数目。
slow_start=time 从不可用转换至可用的时间。

upstream调度算法:

1,rr轮询
类似于lvs的rr算法,如果后端服务器宕机(默认只监控80端口,如果后端报包502,404,403,503还是会返回错误给用户。),机器则会自动剔除。
2,weight权重
权重和访问轮询成正比,权重越大则转发请求越多。
配置:
server 192.168.10.10:80 weight=1;
3,ip_hash
每个请求按访问的ip的hash结果进行分配,只要hash值向同就会把相同的ip地址的请求分配到同一个服务端,该调度算法可以解决session共享问题,但是也有可能使请求分配不均匀,
注意:必须是最前端的服务器,多数情况下不能和weight,bakcup选项一起使用。(session共享问题可以通过设置单独存储session的存储来解决。)
配置:
ip_hash;
4,fair动态算法(三方),
按照后端服务器的响应时间来分配请求,响应时间短的优先分配,比上面算法更加智能的算法,这是Nginx的第三方算法,使用时必须下载upstream_fair模块。
配置:
fair;
5,url_hash(三方)
按照访问url的hash结果来分配请求,让每个url定到相同的服务器,后端服务器为缓存服务器时效果显著,在upstream加入hash语句,server不能写入weight等其他参数。
url_hash。按访问的url hash结果来分配请求,使每个url定向至特定的服务器,可以进一步提高后台缓存服务器的命中效率,nginx本身不支持这种,必须要安装nginx的hash软件包。
配置:
hash $request_url;
hash_method crc32;

2.ngx_http_proxy_module模块

参数 说明
proxy_pass http://blog_server_pool 指定反向代理服务池
proxy_set_header Host $host 当后端web服务器上有多个虚拟主机时,需要用该header来区分主机名称。
proxy_set_header X-Real-IP $remote_addr; 如果后端程序需要从用户获取IP,从该报文header获取。
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for 获取连接代理端的IP地址,多级代理中会有多个值,一般最前面的值时客户端IP地址
client_body_buffer_size 用于指定客户端,请求主机缓冲区大小,可以理解为先保存至本地,再传给客户端。
proxy_connect_timeout 表示和后端服务器连接的超时时间。
proxy_send_timeout 后端服务器数据回传时间,即在规定时间内,后端必须传完所有数据,否则断开连接
proxy_buffer_size 设置缓冲区大小,该缓冲区大小等于proxy_buffer设置的大小。
proxy_buffers 设置缓冲区的数量的大小,nginx从代理的后端服务器获取的响应信息。

proxy_pass指令,此模块可以将请求发送至另外一台服务器,
配置:
location /name/ {
proxy_pass http://127.0.0.1/remote/;
}
proxy_pass参数说明:

参数 说明
proxy_pass http://blog_server_pool 指定反向代理服务池
proxy_set_header Host $host 当后端web服务器上有多个虚拟主机时,需要用该header来区分主机名称。
proxy_set_header X-Real-IP $remote_addr; 如果后端程序需要从用户获取IP,从该报文header获取。
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for 获取连接代理端的IP地址,多级代理中会有多个值,一般最前面的值时客户端IP地址
client_body_buffer_size 用于指定客户端,请求主机缓冲区大小,可以理解为先保存至本地,再传给客户端。
proxy_connect_timeout 表示和后端服务器连接的超时时间。
proxy_send_timeout 后端服务器数据回传时间,即在规定时间内,后端必须传完所有数据,否则断开连接
proxy_buffer_size 设置缓冲区大小,该缓冲区大小等于proxy_buffer设置的大小。
proxy_buffers 设置缓冲区的数量的大小,nginx从代理的后端服务器获取的响应信息。

X-Real-IP和X-Forwarded-For 区别
X-Forwarded-For是一个可叠加的过程,后面的代理会把前面代理的IP加入X-Forwarded-For
X-Real-IP只是个变量会被替换
$remote_addr代表的是他的前面的代理服务器或者客户端的IP地址。
多重代理要想全面了解流程,需要打印日志下面的几个参数。
$remote_addr |$http_x_real_ip |$http_x_forwarded_for
下面有几个案例写的比较清晰,可以参考理解一下:
https://blog.csdn.net/broadview2006/article/details/54570943
配置例子:

location / {
proxy_pass http://localhost:8000
#判断请求出错,会咨询下一个服务器请求
proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504
include proxy.conf;
}
[root@localhost conf]# cat proxy.conf
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_connect_timeout 90;
proxy_send_timeout 90;
proxy_read_timeout 90;
proxy_buffer_size 4k;
proxy_buffers 4 32k;
proxy_busy_buffers_size 64k;
proxy_temp_file_write_size 64k;

Nginx实现动静分离

方案一:

根据访问的url实现动静分离。

location /static/ {
}
location /dyamic/{
}

方案二:
根据扩展名称实现动静分离

location ~ .*\.(css|jpg|png|js|imag)
{
   proxy_pass http://static_pools
}
根据使用客户端$http_user_agent,跳转不同试用页面页面
IE浏览器(MSIE),火狐(Firefox)。
if ($http_user_agent ~* “android”)
{
   proxy_pass http://android_pools
}
if ($http_user_agent ~* “iphone”)
{
   proxy_pass http://iphone_pools
}

参考链接:
http://nginx.org/en/docs/http/ngx_http_proxy_module.html#proxy_pass

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,236评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,867评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,715评论 0 340
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,899评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,895评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,733评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,085评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,722评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,025评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,696评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,816评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,447评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,057评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,009评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,254评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,204评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,561评论 2 343

推荐阅读更多精彩内容