使用Nginx+集群Tomcat实现负载均衡

挺多人平时项目都不会去接触服务器上部署的事情。但是如果你一辈子都只开发模块,对软件开发整个流程不掌握透彻已经掌握各种解决方法。

那么个人劝你们早点离开这行业吧。绝对是累到爆炸也赚的钱少。

关于Nginx最近项目环境上使用的越来越多。大部分分布式的项目或者并发量大的都可能会接触到。本人以前所做的项目以及公司环境没条件只能自己研究

所以整理下博客提早预习。对未来的项目有足够的解决方法以及实施。

回归主题如下:

很多人想要nginx都是以为是一个反向代理。那么对于这个名词我也去找了下度娘解释如下:


反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个服务器。


 说白了就是一个负责把请求分配给其他服务的一个代理服务器。感觉上它有承担了一个服务器的功能一样。下边的实例我先做一个解释说明我们用nginx作为代理服务器去监听一个80端口。实际也部署了一个8080端口的tocmat,来了请求了80端口,然后又被转发到了8080端口处理完毕返回给80的它,错觉感觉变成了nginx去处理了一样。


相比之下配置比apache简单多了。也省去了很多复杂配置。安装也容易多直接下载解压可用。


一、下载

nginx官网:http://nginx.org/

直接到nginx官方下载地址下载即可:http://nginx.org/en/download.html,根据各自的操作系统版本下载。本文选择最新的nginx-1.6.0windows稳定版本。

image

 

二、安装

安装很简单,直接解压到指定的文件目录即可。解压后的目录如下:

image

双击nginx.exe,发现一闪而过的窗口,代表nginx服务已经启动。

 也可以使用命令进行启动,使用命令行进入nginx根目录下:


命令基本上如下:

几秒钟就能掌握的。

到根目录下执行 

start nginx 

直接访问http://localhost可以看到如下图,代表安装启动成功:

image

其他相关命令:

  1. nginx -s stop    快速退出  
  2.   
  3. nginx -s quit    优雅退出  
  4.   
  5. nginx -s reload    更换配置,启动新的工作进程,优雅的关闭以往的工作进程  
  6.   
  7. nginx -s reopen     重新打开日志文件  

三、配置

nginx文件目录下有一个conf文件夹,其中有好几个文件,其他先不管,我们打开nginx.conf,可以看到一段:

  1. server {  
  2.         listen       80;  
  3.         server_name  localhost;  
  4.   
  5.         #charset koi8-r;  
  6.   
  7.         #access_log  logs/host.access.log  main;  
  8.   
  9.         location / {  
  10.             root   html;  
  11.             index  index.html index.htm;  
  12.         }  

这段代码在server里面,相当于一个代理服务器,当然可以配置多个。

下面我们仔细来分析一下:

listen:表示当前的代理服务器监听的端口,默认的是监听80端口。注意,如果我们配置了多个server,这个listen要配置不一样,不然就不能确定转到哪里去了。

server_name:表示监听到之后需要转到哪里去,这时我们直接转到本地,这时是直接到nginx文件夹内。

location:表示匹配的路径,这时配置了/表示所有请求都被匹配到这里

root:里面配置了root这时表示当匹配这个请求的路径时,将会在这个文件夹内寻找相应的文件,这里对我们之后的静态文件伺服很有用。

index:当没有指定主页时,默认会选择这个指定的文件,它可以有多个,并按顺序来加载,如果第一个不存在,则找第二个,依此类推。

下面的error_page是代表错误的页面,这里我们暂时不用,先不管它。

那我们知道了具体的配置了,怎么让它访问localhost时转到tomcat时。实际上就修改两个地方:

  1. server_name localhost:8080;   
  2.   
  3. location / {   
  4.   
  5.     proxy_pass http://localhost:8080;  
  6.   
  7. }    

我们就修改了上面两个地方,我的tomcat在8080端口,可以根据自己的需要修改。这里有一个新元素proxy_pass,它表示代理路径,相当于转发,而不像之前说的root必须指定一个文件夹。

此时我们修改了文件,是不是就意思着必须先关了nginx再重新启动了,其实不必,nginx可以重新加载文件的。

我们直接运行:

 

  1. nginx -s reload   

如果不想直接加载,而只是想检查配置文件有没有问题,可以直接输入:

 

  1. nginx -t    

这可以检查配置文件中是否有错。 下面我们所有的修改都假设我们修改完成后运行了nginx -s reload进行重新加载配置文件,请注意。

一切没问题了,然后我们再重新打开http://localhost,我们看到下面的页面:

image

这时,我们发现它并不是刚才的welcome页面了,而是tomcat的管理页面了,不管我们点击什么链接都是没问题的,相当于直接访问http://localhost:8080一样。


四、配置集群负载均衡

有些人会说,这些都只会找一台服务器,但如果我们想在一台服务器挂了的时候,自动去找另外一台,这怎么办?这实际上nginx都考虑到了。

这时,我们之前用的proxy_pass就有大用途了。

我们把之前的第一个例子,即全部都代理的修改一下:

最后修改如下:

  1. upstream local_tomcat {   
  2.   
  3.     server localhost:8180;   
  4.   
  5. }   
  6.    
  7.   
  8. server{   
  9.         location / {   
  10.   
  11.            proxy_pass http://local_tomcat;   
  12.   
  13.         }   
  14.   
  15.         #......其他省略   
  16.   
  17. }    

 我们在server外添加了一个upstream,而直接在proxy_pass里面直接用http://+upstream的名称来使用。

我们还是直接来http://localhost,还是和第一个一样的效果,所有链接都没问题,说明我们配置正确。

upstream中的server元素必须要注意,不能加http://,但proxy_pass中必须加。

我们刚才说可以在一个服务器挂了的情况下连到另外一个,那怎么弄呢?

其实很简单,在upstream中的local_tomcat中配置多一个server。比如我现在弄多一个tomcat,端口在8280,所以我们配置如下:

  1. upstream local_tomcat {   
  2.     server localhost:8180;   
  3.     server localhost:8280;   
  4. }   

此时,我们关闭tomcat,重新来运行http://localhost看看效果:

image

 我修改了index.jsp页面,增加日志输出信息,便于观察。注意:左上角小猫头上的:tomcat2、tomcat1。说明访问了不同的tomcat。

 但有时我们就不想它挂的时候访问另外一个,而只是希望一个服务器访问的机会比另外一个大,这个可以在server最后加上一个weight=数字来指定,数字越大,表明请求到的机会越大。 

  1. upstream local_tomcat {   
  2.   
  3.     server localhost:8180 weight=1;   
  4.   
  5.     server localhost:8280 weight=3;   
  6.   
  7. }    

这时我们给了8280一个更高的权值,让它更有机会访问到,实际上当我们刷新http://localhost访问的时候发现8280访问机率大很多,8180几乎没机会访问,一般情况下,如果我们必须这样用,不要相关太大,以免一个服务器负载太大。

当然,server还有一些其他的元素,比如down表示暂时不用到该服务器等等。这些可以参考nginx的wiki。也许写了一大堆,有人会有问题,那nginx怎么关闭呢?这倒是个问题,其实直接运行nginx -s stop就可以关闭了。

到此均衡就配置完毕了。

至于它其实也有类似于Tomcat Session同步的问题

正常情况我们会集群配置或者单配置一个缓存服务器作为session同步使用。

或者使用nginx_upstream_jvm_route用来实现基于 Cookie 的 Session Sticky 的功能

若服务器不是很多可以考虑server之间同步session。高并发环境下可能出现Session风暴,乱串。

案例的页面我就不贴图了。反正就是每次访问不同的页面显式。


看到这里了  是不是感觉比apache+mod_jk+tomcat配置好一些呐。

Nginx ("engine x") 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器,因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名


用nginx+tomcat+memcache(or redis)来代替apache+tomcat是趋势。也不能说旧方法不可取。

具体还得看你的学识与掌握与否。在项目的实践场景下得到拓展。









你可能感兴趣的:(分布式,集群)