基于JFinal的程序在Nginx+Tomcat集群配置怎样合理?

江哥一直在 发布于 2013/04/09 17:23
阅读 1K+
收藏 6

云原生2.0展望丨从“小众”到“首选”,推动云原生产业落地华为云作用几何?>>>

大家好, 最近研究OSC上讨论比较多的JFinal开源项目,发现确实很轻量,耦合很低,是一个很不错的、高效的开源东东。。。赞了!!!

小弟弱弱地问一下大家的JFina项目有用Nginx+tomcat集群的吗?nginx.conf配置怎样?
小弟的思路是:
JFinal中没有类似.do 、.jsp 、.action这样的结尾,所有的请求都要经过action跳转,那么nginx在这里全部的请求都要转到tomcat处理,然后再次过滤出js、css、图片等等这些文件,以及gzip压缩等工作。Nginx处理静态页面的能力没有得到体现。

小弟愚笨,请高手指点。尤其是 @红薯 、@JFinal
备注:偷偷看了@红薯 的关于OSChina源码和Nginx的文章,在此感谢了!!

加载中
1
沉寂brain
沉寂brain
这个问题特别的简单   只需要你从nginx拦截  *.js *.html *.png *.jpg *.css 这些静态资源  然后你把动态的资源全部甩到后端的动态服务器
沉寂brain
沉寂brain
回复 @一个搞IT的人 : 肯定是用nginx拦截静态资源了,tomcat处理静态资源会很慢的,直接从nginx过滤就好了,先让nginx检测是不是静态资源,如果是的话用nginx 处理 其他的全部转到tomcat处理
江哥一直在
江哥一直在
先全局拦截,后匹配拦截?先后顺序有影响吗?
1
沉寂brain
沉寂brain
你说的关于gzip压缩的问题 你可以从nginx 上做gzip压缩  交给nginx压缩比交给tomcat压缩更合适
江哥一直在
江哥一直在
恩,是的。都是在nginx中配置开启gzip
1
沉寂brain
沉寂brain
然后关于集群的问题就更简单了 你从nginx 的 
upstream  tomcatserver  {
            server   127.0.0.1:8080;
            server   127.0.0.1:8080;

 }配置多个  然后 还可以设置权重跟主备用 这个你可以看一下nginx的文档

1
Anterior
Anterior
#运行用户
user root;

#启动进程,通常设置为cpu核心数相等
worker_processes 1;

#全局错误日志和PID文件
error_log logs/error.log;
pid logs/nginx.pid;

#工作模式及连接上线
events{
        #epoll是多路复用IO(I/O Multiplexing)中的一种方式,但是仅用于linux2.6以上内核,可以大大提高nginx的性能
        use epoll;
        #单个后台worker process进程的最大并发链接数
        worker_connections 1024;
}

#设定http服务器
http{
        #设定MIME类型
        include /usr/local/nginx/conf/mime.types;
        default_type application/octet-stream;
        #设定access Log
        access_log logs/access.log;

        #sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用,
    #必须设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为 off,以平衡磁盘与网络I/O处理速度,降低系统的uptime.
         sendfile        on;

         #连接超时时间
         #keepalive_timeout  0;
          keepalive_timeout  65;
          tcp_nodelay        on;

         #开启gzip压缩
         gzip  on;
         gzip_disable "MSIE [1-6]\.(?!.*SV1)";

        #设定请求缓冲
         client_header_buffer_size    1k;
         large_client_header_buffers  4 4k;

        #设定负载均衡的服务器列表
        upstream mysvr {
           #weigth参数表示权值,权值越高被分配到的几率越大
           #本机上的Squid开启3128端口
           #server 192.168.8.1:3128 weight=5;
           #server 192.168.8.2:80  weight=1;
           #server 192.168.8.3:80  weight=6;
            server localhost:8080  weight=5;
        }

        server{
                 #监听端口
                 listen 80;
                 #主机名
                 server_name www.dc.com;
                 #设定本虚拟主机访问日志
                 # access logs/access.log main;
                 #默认请求
                 location / {
                        proxy_pass http://localhost:8080;
                        index index.jsp index.html index.ftl;
                        include proxy.conf;
                 }
                 #静态文件 Nginx 自己处理
                 location ~ ^/(img|images|javascript|js|css|flash|media|static)/{
                        root /home/web/resources;
                         #过期30天,静态文件不怎么更新,过期可以设大一点,如果频繁更新,则可以设置得小一点。

                        expires 1h;
                 }

                 # 定义错误提示页面
                error_page 500 502 503 504 /50x.html;
                location = /50x.html{
                        root html;
                }

                #脚本文件 交给后端处理
                #location ~ \.jsp${
                #       proxy_passs http://localhost:8080;
                #}

                 #设定查看Nginx状态的地址
                 #location /NginxStatus {
                        #stub_status            on;
                        #access_log              on;
                        #auth_basic              "NginxStatus";
                        #auth_basic_user_file  conf/htpasswd;
                 #}
        }
}
我是根据 js、img、css的不同路径进行处理的,集群哪里用的是upstream tomcatserver
Anterior
Anterior
@一个搞IT的人 你细心找找有好多,我也是在osc上找到的:)
江哥一直在
江哥一直在
谢谢,谢谢。。。有代码真好!!
JFinal
JFinal
@前路 @...... 正解,简单说:先分别将多个tomcat启动在不同的端口(非80端口)下面,然后在nginx中配置upstream指向这些tomcat,最后通过location+正则使nginx接管所有静态资源请求即可
0
mekain
mekain

JFinal就是java项目,所以集群肯定是没有问题的,具体怎么配置,网上可以找找资料

江哥一直在
江哥一直在
谢谢,正在网上找。
返回顶部
顶部