文档章节

Nginx 手记(九)负载均衡

神奇Sam
 神奇Sam
发布于 2017/08/30 14:47
字数 747
阅读 596
收藏 0

实现原理

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;
}

© 著作权归作者所有

共有 人打赏支持
神奇Sam
粉丝 22
博文 41
码字总数 27998
作品 0
广州
程序员
九、参考资料

《实战 Nginx:取代Apache的高性能Web服务器》 《nginx的五种负载均衡算法》 《Nginx服务器优化》 《nginx 解决session共享》 《nginx tomcat session复制》 《UNIX下Apache 简介及基本配置》...

孟飞阳
2016/08/07
30
0
Ngnix 负载均衡环境搭建

一、NGINX简介 二、NGINX的安装及配置 三、NGINX的配置与优化 四、NGINX与JSP的安装、配置与优化 五、Nginx HTTP负载均衡和反向代理的配置与优化 六、Nginx的Rewrite规则与实例 七、NGINX的非...

孟飞阳
2016/08/07
38
0
【PDF分享】Nginx 常见应用技术指南[Nginx Tips] 第二版.pdf

文档目录: 一、Nginx 基础知识 二、Nginx 安装及调试 三、Nginx Rewrite 四、Nginx Redirect 五、Nginx 目录自动加斜线: 六、Nginx Location 七、Nginx expires 八、Nginx 防盗链 九、Nginx...

鉴客
2010/09/12
1K
4
19个心得 明明白白说Linux下的负载均衡

19个心得 明明白白说Linux下的负载均衡 http://bbs.uchao.net/thread-32910-1-1.html 一、目前网站架构一般分成负载均衡层、web层和数据库层,我其实一般还会多加一层,即文件服务器层,因为...

浩源社区
2012/03/01
0
0
nginx学习九 upstream 负载均衡

语法 后端服务器在负载均衡调度中的状态: nginx 的调度算法: 例 /etc/nginx/conf.d/default.con 加权轮询 备份节点 iphash url_hash 语法(1.7.2版本开始)...

Romanceling
昨天
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

es6

在实际开发中,我们有时需要知道对象的所有属性,原生js给我们提供了一个很好的方法:Object.keys(),该方法返回一个数组 传入对象,返回属性名 var obj = {'a':'123','b':'345'};console.l...

不负好时光
18分钟前
0
0
叮!您收到一份超值Java基础入门资料!

摘要:Java语言有什么特点?如何最大效率的学习?深浅拷贝到底有何区别?阿里巴巴高级开发工程师为大家带来Java系统解读,带你掌握Java技术要领,突破重点难点,入门面向对象编程,以详细示例...

全部原谅
20分钟前
0
0
web.xml容器加载顺序

容器对于web.xml的加载过程是context-param >> listener >> fileter >> servlet

Aeroever
22分钟前
1
0
Docker容器日志查看与清理

1. 问题 docker容器日志导致主机磁盘空间满了。docker logs -f container_name噼里啪啦一大堆,很占用空间,不用的日志可以清理掉了。 2. 解决方法 2.1 找出Docker容器日志 在linux上,容器日...

muzi1994
23分钟前
0
0
J2Cache 和普通缓存框架有何不同,它解决了什么问题?

不少人看到 J2Cache 第一眼时,会认为这就是一个普普通通的缓存框架,和例如 Ehcache、Caffeine 、Spring Cache 之类的项目没什么区别,无非是造了一个新的轮子而已。事实上完全不是一回事!...

红薯
26分钟前
456
14

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部