nginx实现负载均衡

一、Nginx
什么是Nginx?
Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,由俄罗斯的程序设计师Igor Sysoev所开发,供俄国大型的入口网站及搜索引擎Rambler使用。其特点是占有内存少,并发能力强,中国大陆使用nginx网站用户有:百度、新浪、网易、腾讯等。
优点:
1、可运行linux,并有windows 移植版
2、在高并发情况下,Nginx 可支持高达50000个并发连接数的响应。
Nginx如何实现负载均衡?
1、Nginx反向代理
Nginx利用自身反向代理功能,在conf配置文件中添加反向代理地址,以代理服务器的身份接受客户端发送过来的请求,然后将请求转发给内部网络上的应用服务器,并将从服务器上得到的结果返回给客户端,此时代理服务器对外就表现为一个服务器,不过它只负责转发请求,不负责处理。
2、Nginx转发策略
Nginx转发请求可按照调度规则通过轮询、ip哈希、URL哈希、权重等多种方式对应用服务器做负载均衡,同时还支持后端服务器的健康检查,也就是上面讲的故障移除和恢复添加功能。
nginx 的 upstream目前支持的分配算法:

1)、轮询(默认)       每个请求按时间顺序逐一分配到不同的应用服务器,如果应用服务器down掉,能自动剔除。

2)、权重      通过配置权重,指定轮询几率,权重和访问比率成正比,用于应用服务器性能不均的情况。

3)、ip_哈希算法      每个请求按访问ip的hash结果分配,这样每个访客固定访问一个应用服务器,可以解决session共享的问题。

案例

  步骤一:准备两个Tomcat  一个端口为8081,另一个端口为8082;

    

  步骤二:配置nginx.conf文件

    

   步骤三:启动Tomcat和nginx  

    启动Tomcat:这里需要启动两次Tomcat,一次端口为8082,一次端口为8081

      进入Tomcat文件下的bin目录

        

       使用【./startup.sh】 命令启动  

        

      启动后可使用【ps -ef | grep tomcat 】命令查看当前Tomcat的进程

        

    启动nginx:

      进入nginx文件下的sbin目录

        

      使用【./nginx】命令启动nginx

        

      使用【ps -ef | grep nginx】命令查看当前nginx进程

         

      实现效果:默认的负载均衡采用轮询机制的,每个请求按时间顺序逐一分配到不同的后端服务器上,如果后端服务器down掉,能自动剔除;按照http://www.b.com访问页面。

nginx实现负载均衡的方式

  1.轮询

    每个请求按时间顺序逐一分配到不同的后端服务器上,如果后端服务器down掉,能自动剔除;

      

  2.权重(weight)

    weight代表权,重默认为1,权重越高被分配的客户端越多;

    指定轮询几率,权重和访问比率成正比,用于后端服务性能不均的请求下。

        

  3.ip_hash

    每个请求按访问IP的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题;

      

  4.第三方(fair)

    按后端服务器的响应时间来分配请求,响应时间短的优先分配;

      

原文地址:https://www.cnblogs.com/lowerma/p/12284736.html