Tomcat结合Nginx使用入门

Nginxcss

  1. Nginx是一款高性能,轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。html

  2. 特色是:占有内存少,并发能力强。
    java

    反向代理服务器:
    nginx

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

通俗的讲:
web

      反向代理方式实际上就是一台负责转发的代理服务器,貌似充当了真正服务器的功能,但实际上并非,代理服务器只是充当了转发的做用,而且从真正的服 务器那里取得返回的数据。这样说,其实nginx完成的就是这样的工做。咱们让nginx监听一个端口,譬如80端口,但实际上咱们转发给在8080端口 的tomcat,由它来处理真正的请求,当请求完成后,tomcat返回,但数据此时没直接返回,而是直接给nginx,由nginx进行返回,这里,我 们会觉得是nginx进行了处理,但实际上进行处理的是tomcat。apache

说到上面的方式,也许不少人又会想起来,这样能够把静态文件交由nginx来进行处理。对,不少用到nginx的地方都是做为静态伺服器,这样能够方便缓存那些静态文件,好比CSS,JS,html,htm等文件。windows

Nginx怎么使用缓存

1)要用到的软件固然要下载啦。到nginx官网下一个。http://nginx.org/en/download.html能够到这里去下。tomcat

这里,因为个人是windows,固然下windows版啦。下完后首先要启动吧。进入到nginx文件夹,直接start nginx就OK了。服务器

好比我下载后放在D:\software \developerTools\server\nginx-1.1.7,直接cmd后cd D:\software\developerTools \server\nginx-1.1.7,有些不习惯命令行的可能会奇怪,它没有进行到那个文件夹。windows并不会在分区间跳转,除非你本身指定 了。因此咱们要直接d:以下:

而后,咱们直接start nginx,这里也许你会看到一个窗口一闪而过,根据咱们使用tomcat的经验,若是一闪而过,证实有错误了,是吧?但实际上不是。

此时咱们打开任务管理器,能够看到两个nginx.exe在那里好好的。这说明咱们已经启动了,至于为何两个,咱们这里不深究。

如今,咱们已经启动了nginx,这时就能够启动tomcat,想着直接访问http://localhost就能够直接访问tomcat了。

先不急,咱们来看看启动后的nginx是怎样的。直接访问http://localhost能够看到:

    咱们能够看到nginx启动成功,如今访问是直接进到nginx的目录里面了。

那么这些其实是在哪里配置的。这就涉及到nginx的一个重要配置文件nginx.conf了。

 

2)咱们能够看到nginx文件夹内有一个conf文件夹,其中有好几个文件,其余先无论,咱们打开nginx.conf,能够看到一段:

 这段代码在server里面,至关于一个代理服务器,固然能够配置多个。

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

listen:表示当前的代理服务器监听的端口,默认的是监听80端口。注意,若是咱们配置了多个server,这个listen要配置不同,否则就不能肯定转到哪里去了。

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

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

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

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

下面的error_page是表明错误的页面,这里咱们暂时不用,先无论它。

 

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

Java代码  收藏代码

  1. server_name localhost:8080;  

  2.   

  3. location / {  

  4.     proxy_pass http://localhost:8080  

  5. }  

 咱们就修改了上面两个地方,个人tomcat在8080端口,能够根据本身的须要修改。这里有一个新元素proxy_pass,它表示代理路径,至关于转发,而不像以前说的root必须指定一个文件夹。

此时咱们修改了文件,是否是就意思着必须先关了nginx再从新启动了,其实没必要,nginx能够从新加载文件的。

咱们直接运行:

Html代码  收藏代码

  1. nginx -s reload  

高兴得太早了,咱们发现有一个错误:

 什么来的,45行发现错误,不但愿在那一行找到},因而咱们仔细找,发现咱们加入的proxy_pass很奇怪,没有;号结尾,这就是问题了,直接修改,而后再运行一下,发现没错误,OK了。

若是不想直接加载,而只是想看看本身的配置文件有没有问题,能够直接输入:

Xml代码  收藏代码

  1. nginx -t  

这能够检查配置文件中是否有错。 下面咱们全部的修改都假设咱们修改完成后运行了nginx -s reload进行从新加载配置文件,请注意。

 

一切没问题了,而后咱们再从新打开http://localhost,咱们看到下面的页面:

 

这时,咱们发现它并非刚才的welcome页面了,而是tomcat的管理页面了,无论咱们点击什么连接都是没问题的,至关于直接访问http://localhost:8080同样。

 

3)上面咱们直接试了一个小例子,让nginx进行转发,即所 谓的反向代理。但实际上咱们的需求不会是这样的,咱们须要分文件类型来进行过滤,好比jsp直接给tomcat处理,由于nginx并非servlet 容器,没办法处理JSP,而html,js,css这些不须要处理的,直接给nginx进行缓存。

下面咱们来进行一下配置,让JSP页面直接给tomcat,而html,png等一些图片和JS等直接给nginx进行缓存。

这时最主要用的仍是location这个元素,而且涉及到一部分正则,但不难:

Xml代码  收藏代码

  1. location ~ \.jsp$ {  

  2.         proxy_pass http://localhost:8080;  

  3. }  

  4.           

  5. location ~ \.(html|js|css|png|gif)$ {  

  6.     root D:/software/developerTools/server/apache-tomcat-7.0.8/webapps/ROOT;  

  7. }  

 咱们先要去掉以前配的location /,避免所有请求被拦截了。

而后咱们再来看看http://localhost

 当咱们不指定jsp页面的时候,它会出现找不到,由于,此时并无相应的location匹配,因此就会有404错误,这时就跳到了nginx自定义的error页面去了。

而当咱们用http://localhost/index.jsp去访问时,咱们看到了熟悉的页面:

 并且图片那些都显示正常,由于图片是png的,因此直接在tomcat/webapps/ROOT目录下直接查找,固然,若是咱们点击Manager Application HOW-TO这个连接,咱们发现:

 它仍是找不到,为何呢?由于这是个html页面,但它并不在ROOT目录下,而是在docs目录下,但当咱们匹配html时,咱们却到ROOT目录下去找,因此仍是找不到这个页面。

 

通常状况下,若是咱们须要用nginx来进行静态文件伺服,通常都会把全部静态文件,html,htm,js,css等都放在同一个文件夹下,这样就不会有tomcat这样的状况了,由于tomcat下的是属于不一样的项目,这个咱们就没办法了。

 

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

这时,咱们以前用的proxy_pass就有大用途了。

咱们把以前的第一个例子,即所有都代理的修改一下:

最后修改以下:

Xml代码  收藏代码

  1. upstream local_tomcat {  

  2.     server localhost:8080;  

  3. }  

  4.   

  5. server{  

  6.         location / {  

  7.            proxy_pass http://local_tomcat;  

  8.         }  

  9.         #......其余省略  

  10. }  

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

咱们仍是直接来http://localhost,仍是和第一个同样的效果,全部连接都没问题,说明咱们配置正确。

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

咱们刚才说能够在一个服务器挂了的状况下连到另一个,那怎么弄呢?

其实很简单,在upstream中的local_tomcat中配置多一个server。好比我如今弄多一个jetty,端口在9999,因此咱们配置以下:

Xml代码  收藏代码

  1. upstream local_tomcat {  

  2.     server localhost:8080;  

  3.     server localhost:9999;  

  4. }  

 此时,咱们关闭tomcat,而只开jetty。咱们来运行http://localhost看看效果:

 咱们看到它请求到了jetty的页面,但因为jetty的机制,这时没有显示jetty主页,这个咱们先无论。但咱们的在一个服务器挂的状况下自动使用另一个的功能实现了。

 

但有时咱们就不想它挂的时候访问另一个,而只是但愿一个服务器访问的机会比另一个大,这个能够在server最后加上一个weight=数字来指定,数字越大,代表请求到的机会越大。

Xml代码  收藏代码

  1. upstream local_tomcat {  

  2.     server localhost:8080 weight=1;  

  3.     server localhost:9999 weight=5;  

  4. }  

 这时咱们给了jetty一个更高的权值,让它更有机会访问到,实际上当咱们刷新http://localhost访问的时候发现jetty访问机率大不少,tomcat几乎没机会访问,通常状况下,若是咱们必须这样用,不要相关太大,以避免一个服务器负载太大。

固然,server还有一些其余的元素,好比down表示暂时不用到该服务器等等。这些能够参考nginx的wiki。

        nginx关闭:直接运行nginx -s stop就能够关闭了。

相关文章
相关标签/搜索