• 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)

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

          

  • 相关阅读:
    数据库中的 索引
    JQuery中ajax请求
    如何优化广告,提高点击率
    常用的正则表达式
    全栈工程师之路中级篇之小程序开发前言
    ionic入门教程第四课使用$controllerProvider按需加载controller
    全栈工程师之路中级篇之小程序开发第一章第一节注册小程序
    ionic入门教程第三课在项目中使用requirejs分离controller文件和server文件
    ionic入门教程第五课举例子说明异步回调$q及$q在项目中的用法
    求两个整数的最大公约数和最小公倍数
  • 原文地址:https://www.cnblogs.com/lowerma/p/12284736.html
Copyright © 2020-2023  润新知