• nginx负载均衡


    Nginx负载均衡优缺点

    	- Nginx的优点是:
    	1、工作在网络的7层之上,可以针对http应用做一些分流的策略,比如针对域名、目录结构,它的正则规则比HAProxy更为强大和灵活,这也是它目前广泛流行的主要原因之一,Nginx单凭这点可利用的场合就远多于LVS了。
    	2、Nginx对网络稳定性的依赖非常小,理论上能ping通就就能进行负载功能,这个也是它的优势之一;相反LVS对网络稳定性依赖比较大,这点本人深有体会;
    	3、Nginx安装和配置比较简单,测试起来比较方便,它基本能把错误用日志打印出来。LVS的配置、测试就要花比较长的时间了,LVS对网络依赖比较大。
    	3、可以承担高负载压力且稳定,在硬件不差的情况下一般能支撑几万次的并发量,负载度比LVS相对小些。
    	4、Nginx可以通过端口检测到服务器内部的故障,比如根据服务器处理网页返回的状态码、超时等等,并且会把返回错误的请求重新提交到另一个节点,不过其中缺点就是不支持url来检测。比如用户正在上传一个文件,而处理该上传的节点刚好在上传过程中出现故障,Nginx会把上传切到另一台服务器重新处理,而LVS就直接断掉了,如果是上传一个很大的文件或者很重要的文件的话,用户可能会因此而不满。
    	5、Nginx不仅仅是一款优秀的负载均衡器/反向代理软件,它同时也是功能强大的Web应用服务器。LNMP也是近几年非常流行的web架构,在高流量的环境中稳定性也很好。
    	6、Nginx现在作为Web反向加速缓存越来越成熟了,速度比传统的Squid服务器更快,可以考虑用其作为反向代理加速器。
    	7、Nginx可作为中层反向代理使用,这一层面Nginx基本上无对手,唯一可以对比Nginx的就只有lighttpd了,不过lighttpd目前还没有做到Nginx完全的功能,配置也不那么清晰易读,社区资料也远远没Nginx活跃。
    	8、Nginx也可作为静态网页和图片服务器,这方面的性能也无对手。还有Nginx社区非常活跃,第三方模块也很多。
    	淘宝的前端使用的Tengine就是基于nginx做的二次开发定制版。
    	
    	- Nginx的缺点是:
    	1、Nginx仅能支持http、https和Email协议,这样就在适用范围上面小些,这个是它的缺点。
    	2、对后端服务器的健康检查,只支持通过端口来检测,不支持通过url来检测。不支持Session的直接保持,但能通过ip_hash来解决。
    

    1 轮询

    轮询方式是Nginx负载默认的方式,顾名思义,所有请求都按照时间顺序分配到不同的服务上,如果服务Down掉,可以自动剔除,如下配置后轮训10001服务和10002服务。
    
    upstream  dalaoyang-server {
    	   server    localhost:10001;
    	   server    localhost:10002;
    }
    

    2 权重

    指定每个服务的权重比例,weight和访问比率成正比,通常用于后端服务机器性能不统一,将性能好的分配权重高来发挥服务器最大性能,如下配置后10002服务的访问比率会是10001服务的二倍。
    
    upstream  dalaoyang-server {
    	   server    localhost:10001 weight=1;
    	   server    localhost:10002 weight=2;
    }
    

    3 iphash

    每个请求都根据访问ip的hash结果分配,经过这样的处理,每个访客固定访问一个后端服务,如下配置(ip_hash可以和weight配合使用)。
    
    upstream  dalaoyang-server {
    	   ip_hash; 
    	   server    localhost:10001 weight=1;
    	   server    localhost:10002 weight=2;
    }
    ##4 最少连接
    将请求分配到连接数最少的服务上。
    
    upstream  dalaoyang-server {
    	   least_conn;
    	   server    localhost:10001 weight=1;
    	   server    localhost:10002 weight=2;
    }
    

    5 fair

    按后端服务器的响应时间来分配请求,响应时间短的优先分配。
    
    upstream  dalaoyang-server {
    	   server    localhost:10001 weight=1;
    	   server    localhost:10002 weight=2;
    	   fair;  
    }
    

    6 Nginx配置

    以轮训为例,如下是nginx.conf完整代码。
    
    worker_processes  1;
    
    events {
    	worker_connections  1024;
    }
    
    
    http {
       upstream  dalaoyang-server {
    	   server    localhost:10001;
    	   server    localhost:10002;
       }
    
       server {
    	   listen       10000;
    	   server_name  localhost;
    
    	   location / {
    		proxy_pass http://dalaoyang-server;
    		proxy_redirect default;
    	  }
    
    	}
    
    }
    

    7 总结

    	例如一台服务器本身的性能能够支持1w个业务并发处理
    	如果业务并发少于1w个,机器也能负重前行
    
    	但是如果有5w个怎么办呢
    	简单的办法是使用nginx做前面的类似于堡垒机
    	10w个并发都打到这个nginx
    	但是nginx本身不处理业务,所以他能接纳10w个并发,但是他本身没有处理能力
    	而是把这个10w个并发,按照一定的策略分配给后面的其他机器
    	这样的好处是
    	1.通过1个nginx+n个后面的机器组成一个小集群,能处理超过单台机器接纳的上线
    	2.对外提供服务一般会固定一个ip,而往往你的业务一个ip(也就是单台服务器)不能完全处理,那么找一个性能不错的专门负责转发外面的业务请求(一般这种对服务器的压力不会太大),然后发给真正需要处理业务的后面的例如tomcat去,这样能够对外提供一致的提供服务的点
    
    	如果并发有50w个怎么办?
    	这种即使仅仅是转发,单个nginx都没法处理,性能要求太高,而且即使性能能够跟上,操作系统的端口数也是有限的
    	这个时候就需要高级的转发服务器了
    	这方面有硬件的例如f5或者软件的ha
    	然后将请求分发给nginx,nginx再分发给具体处理业务的例如tomcat
    	但是功能都是一样的:提供统一的对外访问入口,转发请求给真正的执行者
    希望你眼眸有星辰,心中有山海,从此以梦为马,不负韶华
  • 相关阅读:
    leetcode203
    leetcode88
    leetcode219
    leetcode225
    2018-12-25-C#-使用转换语义版本号
    2018-12-25-C#-使用转换语义版本号
    2018-10-15-Winforms-可能遇到的-1000-个问题
    2018-10-15-Winforms-可能遇到的-1000-个问题
    2018-8-10-UWP-WPF-解决-xaml-设计显示异常
    2018-8-10-UWP-WPF-解决-xaml-设计显示异常
  • 原文地址:https://www.cnblogs.com/daviddd/p/12603755.html
Copyright © 2020-2023  润新知