Nginx实现负载均衡

作者: 一觉睡到丶小时候 | 来源:发表于2018-08-14 15:13 被阅读14次

    负载均衡即是代理服务器将接收的请求均衡的分发到各服务器中。

    负载均衡的优势在访问量少或并发小的时候可能并不明显,且不说淘宝双11、铁道部抢票这种级别的访问量、高并发,就是一般网站的抢购活动时,也会给服务器造成很大压力,可能会造成服务器崩溃。而负载均衡可以很明显的减少甚至消除这种情况的出现,下面我们说说实现方法。

    准备工作:

    首先下载安装Nginx。

    image

    下载完成解压到本地盘符。解压后是这样的

    image

    注意:nginx.exe是启动的程序,为了方便我们可以手写两个bat文件:

    image

    我将nginx解压到了我本地的E盘

    reload.bat

    E:
    cd kit\nginx-1.14.0\
    nginx  -s reload
    

    stop.bat

    E:
    cd  kit\nginx-1.14.0\
    nginx -s stop
    

    我们双击nginx.exe就可以启动nginx,我们启动一下,打开任务 管理器看到

    image

    就说明启动成功。

    接下来配置两个tomcat来进行测试,下面是我本地的tomcat,存放在E盘中。

    image

    拷贝一份放到我的D盘中,并修改端口号,默认 为8080,我们将D盘中的tomcat端口号修改为8082,将E盘中的tomcat端口号修改为8081。

    端口号的修改:

    找到conf

    image

    修改

    image

    修改如下:

    <Server port="8006" shutdown="SHUTDOWN">  
    <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />  
    <Listener className="org.apache.catalina.core.JasperListener" />  
    <Listener className="org.apache.catalina.mbeans.ServerLifecycleListener" />  
    <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />  
    <GlobalNamingResources>    
     <Resource name="UserDatabase"
                       auth="Container"             
                       type="org.apache.catalina.UserDatabase"              
                      description="User database that can be updated and saved"              
                      factory="org.apache.catalina.users.MemoryUserDatabaseFactory"              
                     pathname="conf/tomcat-users.xml" />  
    </GlobalNamingResources>  
    <Service name="Catalina">    
    <Connector port="8082" 
                       protocol="HTTP/1.1"                
                       connectionTimeout="20000"                
                       redirectPort="8443" />            
    <Connector port="8010" 
                        protocol="AJP/1.3" 
                        redirectPort="8443" />    
    <Engine name="Catalina" defaultHost="localhost">      
    <Realm className="org.apache.catalina.realm.UserDatabaseRealm"             
                 resourceName="UserDatabase"/>      
    <Host name="localhost"  
              appBase="webapps"            
              unpackWARs="true" 
              autoDeploy="true"            
              xmlValidation="false" 
              xmlNamespaceAware="false">     
     </Host>    
    </Engine>  
    </Service>
    </Server>
    

    将E盘中的tomcat端口号修改为8081;只需修改默认文件中的一点

        <Connector port="8081" 
                           protocol="HTTP/1.1"               
                           connectionTimeout="20000"              
                          redirectPort="8443" />        
    

    配置nginx的配置文件:

    image

    找到文件中的server节点,然后再上面添加

    upstream local_tomcat_test {          
              server localhost:8082 weight=8 max_fails=3 fail_timeout=30s;           
              server localhost:8081 weight=2 max_fails=3 fail_timeout=30s;    
     }   
    

    然后修改server:

    upstream local_tomcat_test {          
           server localhost:8082 weight=8 max_fails=3 fail_timeout=30s;          
           server localhost:8081 weight=2 max_fails=3 fail_timeout=30s;    
     }      
    server {        
          listen       80;        
          server_name  localhost;        
    location / {            
         proxy_pass http://local_tomcat_test;            
         #root html;           
         #index index.html index.htm       
     } 
    

    配置完成后,启动两个tomcat,为了区分是哪个tomcat,我把tomcat的默认访问页进行了修改。

    image image

    然后我们再地址栏输入localhost,试试效果:

    image

    访问了tomcat-8082,刷新一下:

    image

    可以看到访问了tomcat-8081

    各参数的含义:

    worker_processes:工作进程个数,可配置多个
    worker_connections:单个进程最大连接数
    server:每一个server相当于一个代理服务器
    lister:监听端口,默认80
    server_name:当前服务的域名,可以有多个,用空格分隔(我们是本地所以是localhost)
    location:表示匹配的路径,这时配置了/表示所有请求都被匹配到这里
    index:当没有指定主页时,默认会选择这个指定的文件,可多个,空格分隔
    proxy_pass:请求转向自定义的服务器列表
    upstream name{ }:服务器集群名称
    

    小结:

    nginx作为一个反向代理服务器,能缓存我们项目的静态文件,并实现反向代理与均衡负载,可以有效减少服务器压力,即使项目不大,也可以使用。

    大家另外应该都还发现了个问题,虽然这样请求能分别请求到两个tomcat上,如果是一般不需身份校检的或什么认证的方法尚可,但如果出现这类情况:

    我们在tomcat1上进行了登录,这时用户session当然是存在tomcat1上的,而这时进入个人中心的请求请求到tomcat2上了,这时就会出现问题了。tomcat2会告诉你还未登录,这显然不是我们想看到的。

    这就涉及到session共享了,如何让两个服务器上的session共用。我这里放到下次再说,可能要过个好几天。

    感谢大家支持。

    相关文章

      网友评论

        本文标题:Nginx实现负载均衡

        本文链接:https://www.haomeiwen.com/subject/fcrvbftx.html