首先探讨一下为什么要使用nginx:
1、类似于apache+resin,nginx用于提供静态页面服务,比java服务器要强。虽然这些java服务器的性能都不赖,tomcat新版甚至还支持了epoll,但是用nginx来处理静态文件是一定比这些服务器更稳妥并更快速的。
2、nginx在配合java应用服务器时相比apache耦合度更低,所以它可以用相同的方式连上所有能支持http服务能力的java应用服务器,无论是tomcat、resin、weblogic、jetty、websphere……,并且可以轻易地将一个应用同时连接不相同的服务器。譬如一台跑tomcat,一台跑resin,这一点在切换或测试生产环境时非常有用。另外耦合度的降低,将使nginx和这些服务器之间的相互影响降到最低,这样两者就能各尽其责,apache一般是采用一个模块来和java应用服务器打交道,这个模块是会对apache的运行或多或少产生影响的,nginx告诉我们这些模块是多么的鸡肋,java服务器要不就往fastcgi协议支持方面发展会更好。
3、nginx的一些特性可以保住脆弱的java服务器。其中可以点名的:1是可细致定制的负载均衡策略;2是超强的故障屏蔽功能可以做到不遗漏任何一个请求;3是客户端连接的异步处理;4是比java服务器强上百倍的负荷能力。
综合这些优点,一般的java应用服务器,接上一个nginx后,在服务稳定性上将可匹敌数万美金的大型java集群服务器,java开发者就不用再为java性能方面发愁了。
如果决定试用一下nginx,那接下来的事就比吐口水轻松得多了。
nginx可以用两种方式去接java后台:
1、将jsp扩展名的请求发往后台,这是比较传统的方式
2、将所有请求都发往后台,而将一些静态文件的目录留下
3、将所有请求都发往后台,而将某种扩展名的链接留下
这三种方式都是利用链接特征处理的,举例说明(例子中是服务器是单机):
首先配置一个upstream,这是通用的:
upstream www.sudone.com {
server 127.0.0.1:8081;
server 127.0.0.1:8082;
}
127.0.0.1:8081和127.0.0.1:8082就是后端服务器了,resin支持两种方式服务,一种是引擎方式用于连接apache和IIS,另一种是http server方式,一定要启动的是http服务器方式的,这样这两个端口才有效。tomcat我不太清楚,如果有两种方式,也一定要启动http server方式,检查的办法是通过一个链接要能够直接访问得到页面。
针对扩展名的策略的配置:
server {
listen 80;
server_name www.sudone.com;
location / {
root /data/html/;
rewrite "^/([0-9]+)\.html$" /a.jsp?id=$1 last;
}
location ~ (\.jsp)|(\.do)$ {
proxy_pass http://www.sudone.com;
}
}
需要注意的事项是:
1、location ~ (\.jsp)|(\.do)$这一段中的proxy_pass标签后面一定不要写/,也不能多写/jsp,例如不能写成proxy_pass http://www.sudone.com/;,原因是location如果用到正则表达式,则不能在proxy_pass中含有链接路径。
2、server_name www.sudone.com;指定的是用户访问nginx时用的域名,proxy_pass http://www.sudone.com;这个是nginx upstream的名称,同时是nginx访问后台用的域名,多数情况下用相同名称就可以了,有一些特殊情况需要用到不相同名称的,则要确保后台不会因为这一点惹出乱子。
3、rewrite直接写在location /下面就可以了,不能写在location ~ (\.jsp)|(\.do)$里面,注意rewrite后面的参数在这里一定要是last。
4、我在此配置里仅仅配置了jsp和do,当然java还不只支持这么多,所以要找到所有java链接规则才可以。
把所有请求都发往后台的配置(2和3一起写了):
server {
listen 80;
server_name www.sudone.com;
location / {
proxy_pass http://www.sudone.com;
}
location /images/ {
alias /data/html/images/;
}
location ~ (\.jpg)|(\.gif)|(\.png)$
{
root /data/html/;
}
}
这两种配置和针对jsp扩展名的原理刚好是反的,注意事项:
1、和针对jsp扩展名不同,在proxy_pass http://www.sudone.com;这里,因为没有用到正则表达式,所以可以在后面写/,亦可支持/jsp。
2、location /images/这一段用alias会能看得比较清楚,也可以用root标签,不过这时就应该写成:root /data/html/,提前一级。
3、location ~ (\.jpg)|(\.gif)|(\.png)$这一段只能用root标签,不能写alias,location用正则后再用alias的话nginx不支持,我也想不清楚用alias的话逻辑会是怎样的。
以上配置都是最简化的配置,还有很多参数可以调整,我在我其他文章里会有所讲述。另外提醒,要好好测试,有问题先思考,这些配置都不是万能配置还不足以能解决所有情况,同时这几种配置也没有优劣之说,如果不确定用哪种,采用第一种方式就可以了。
分享到:
相关推荐
nginx配合tomcat、resin等java应用服务器提供java支持.rar
利用yum(黄狗)安装nginx,mysql,通过下载tomcat,jdk并安装。此处用mysql数据库(修改明文密码为复杂密码,不区分大小写设置)。设置tomcat,nginx相应的端口,路径等等。有需要即下载吧!
详细说明了windows服务器nginx+tomcat+mysql部署及配置(配置阿里云后台安全组,配置域名)很适合新手学习 附件中包含: 1.操作说明文档 2.操作录屏 3.安装所用到的软件安装包 1)Windows Server 2019 数据中心版 ...
nginx-tomcat整合实现JAVA程序负载均衡
使用Tomcat搭建视频服务器,后面又在Ubuntu上用Nginx做了一套。使用ffmpeg处理视频文件为HLS协议的分片以支持点播。
Nginx+tomcat配置集群负载均衡实现动静分离实例
Nginx+tomcat+redis软负载均衡需要的一整套资源,还包括了JDK,依赖包等文件
linux下Nginx+tomcat整合的安装与配置
把java开发的war包后更新到linux服务器后,通过本资源的配置nginx+tomcat实现两台服务器负载均衡,并配置了https的访问方式,并同时支持ipv6网络的访问
Nginx+tomcat7+java1.7+memcached进行共享session缓存必须的一些jar包,支持nginx和memcached任意版本,但tomcat仅限7.X版本,Java的JDK版本最好用1.7的。
这个是pdf文档,讲授nginx和tomcat整合的方法!
nginx_tomcat8_redis负载均衡demo
自己做的一个nginx+tomcat+redis完成session共享小例子,包括所需jar,适合初学者,希望大家一起学习交流
Nginx Tomcat实现动静分离 就目前来说是Nginx结合Tomcat 比较好的一篇负载均衡应用文档
nginx windows tomcat8负载均衡
Nginx和tomcat上传文件大小限制修改,Ngnix和tomcat默认对上传文件大小有限制。
Nginx+Tomcat+Redis实现应用服务器集群负载均衡和Session共享所需要的所有jar包,包括如下jar包:commons-logging-1.2.jar,commons-pool2-2.6.0.jar,jedis-2.9.0.jar,tomcat-juli-7.0.90.jar,tomcat-redis-...
最近学习Nginx+tomcat实现 负载均衡。 首先大家注意: 本文章中没有session共享,关于session共享我会在下一篇中讲解,先实现Nginx+tomcat负载均衡再实现session共享。 从网上查了好多资料,多走了很多弯路,现在把...
nginx+tomcat集群配置文件