Nginx+Resin 负载均衡 实现高性能JAVA平台搭建

2016 年 10 月 20 日 0 条评论 1.92k 次阅读 0 人点赞

现在流行的JavaEE容器有很多:Tomcat、ResinJBossGlassfish等,我们常用的主要是前三种,那这个java容器性能方面到底谁更稳定,并发能力更强呢?那当属resin了,resin官方发布了最新版本4.0.49版,号称并发超越apache,不仅支持jsp语言,还能支持php

我们以前大多用过tomcat,知道tomcat如果要在一台机器配置多个服务,只需要拷贝不同的配置文件,然后配置不同的端口就ok,相比较而言,resin要想在一台机器配置多个服务,就比较麻烦了,那今天我们一起来研究一下。

一、系统环境

系统环境:CentOS 6.0x86_64 
Nginx版本:Nginx-1.10.2 
Resin版本:Resin-4.0.49 
JDK版本: JDK-1.8

二、Nginx安装

    #首先下载需要安装的软件:【JDK可以去java官网下载并安装】  
    wget http://nginx.org/download/nginx-1.10.2.tar.gz   
    wget http://www.caucho.com/download/resin-4.0.49.tar.gz   
    tar zxvf nginx-1.10.2.tar.gz    
    cd nginx-1.10.2/    
    ./configure--user=www --group=www --add-module=../ngx_cache_purge-1.4 
    \--prefix=/usr/local/nginx\--with-http_stub_status_module --with-http_ssl_module 
    make && make install  

三、Resin安装

    tar –xzvf  resin-4.0.49.tar.gz 
    cd resin-4.0.49 &&./configure  --prefix=/usr/local/resin 
    \--with-resin-log=/data/logs/resin/ --with-java-home=/usr/java/jdk1.8/
    make &&make install

四、配置Resin

    #cd /usr/local/resin/conf/下 
    #添加如下代码,在本机配置两个实例端口为8080、8081 
    <cluster id="app1">
        <!-- define the servers in the cluster -->
        <server-multi id-prefix="app1"address-list="${app1_servers}"port="6800"/>
        <!-- the default host, matching any host name -->
        <host id=""root-directory=".">
            <web-app id="/"root-directory="/var/www/html/app1"/>
        </host>
    </cluster>
    <cluster id="app2">
        <!-- define the servers in the cluster -->
        <server-multi id-prefix="app2"address-list="${app2_servers}"port="6801"/>
        <!-- the default host, matching any host name -->
        <host id=""root-directory=".">
            <web-app id="/"root-directory="/var/www/html/app2"/>
        </host>
    </cluster>

修改当前目录vi resin.properties 修改如下内容:

    # app-tier Triad servers: app-0 app-1 app-2 
    app1_servers      : 127.0.0.1:6800 
    app2_servers      : 127.0.0.1:6801 

    # Use overrides for individual server control, for example: app-0.http : 8081 
    app1.http          : 8080 
    app2.http          : 8081

配置不同的端口,然后启动resin服务:
/usr/local/resin/bin/resin.sh start 即可
然后查看resin 端口 netstat –tnl 我们会看到8080、8081端口

五、配置Nginx
随着Nginx高性能Web服务器大量被使用,目前Nginx最新稳定版为1.10.2,作者在实际应用中大量使用Nginx,并分享Nginx高性能Web服务器知识,使得Nginx在国内也是飞速的发展。那今天咱们再来温习一下Nginx 动静分离知识,这里仅供参考。

一、实践环境:

    系统版本:CentOS6.0 X86_64 
    Nginx版本:Nginx-1.10.2 
    Tomcat版本:Tomcat-7

二、Nginx安装:
实际环境中安装Nginx,首先需要安装pcre库,然后再安装Nginx:

    #安装pcre支持rewrite库,也可以安装源码,注*安装源码时,指定pcre路径为解压源码的路径,而不是编译后的路径,否则会报错。
    yum install pcre-devel pcre -y

    #下载Nginx源码包
    cd /usr/src
    wget -c http://nginx.org/download/nginx-1.10.2.tar.gz

    #解压Nginx源码包
    tar -xzf nginx-1.10.2.tar.gz 

    #进入解压目录,然后sed修改Nginx版本信息为TDTWS 
    cd nginx-1.10.2 ; sed -i -e 's/1.10.2//g' -e 's/nginx\//TDTWS/g' -e 's/"NGINX"/"TDTWS"/g' src/core/nginx.h 

    #预编译Nginx
    ./configure --user=www --group=www --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module
    #.configure预编译成功后,执行make命令进行编译

    make
    #make执行成功后,执行make install 正式安装
    make install
    #自此Nginx安装完毕!!! 

三、配置Nginx:
这里鉴于我的博客已经有Tomcat安装和配置了,这里忽略,只配置Nginx。

#进入Nginx应用目录
cd /usr/local/nginx/conf 
#备份原nginx.conf文件
mv nginx.conf  nginx.bak 

创建 vi nginx.conf ,并写入如下内容:

    user www www; 
    worker_processes 8; 
    worker_cpu_affinity 00000001 00000010 00000100 00001000 00010000 00100000 01000000 10000000; 
    pid /usr/local/nginx/nginx.pid; 
    worker_rlimit_nofile 102400; 

    events 
    { 
        use epoll; 
        worker_connections 102400; 
    } 

    http 
    { 
      include       mime.types; 
      default_type  application/octet-stream; 
      fastcgi_intercept_errors on; 
      charset  utf-8; 
      server_names_hash_bucket_size 128; 
      client_header_buffer_size 4k; 
      large_client_header_buffers 4 32k; 
      client_max_body_size 300m; 

      sendfile on; 
      tcp_nopush     on; 
      keepalive_timeout 60; 
      tcp_nodelay on; 

      client_body_buffer_size  512k; 
      proxy_connect_timeout    5; 
      proxy_read_timeout       60; 
      proxy_send_timeout       5; 
      proxy_buffer_size        16k; 
      proxy_buffers            4 64k; 
      proxy_busy_buffers_size 128k; 
      proxy_temp_file_write_size 128k; 

      gzip on; 
      gzip_min_length  1k; 
      gzip_buffers     4 16k; 
      gzip_http_version 1.1; 
      gzip_comp_level 2; 
      gzip_types       text/plain application/x-javascript text/css application/xml; 
      gzip_vary on; 

    ###2016-10-20 change nginx logs 
    log_format  main  '$http_x_forwarded_for - $remote_user [$time_local] "$request" ' 
                  '$status $body_bytes_sent "$http_referer" ' 
                  '"$http_user_agent"  $request_time $remote_addr'; 

    #这里为后端服务器wugk应用集群配置,根据后端实际情况修改即可,server_web 为负载均衡名称,可以任意指定
    #但必须跟vhosts.conf虚拟主机的pass段一致,否则不能转发后端的请求。 
    upstream server_web { 
        server   10.10.141.30:8080 weight=1max_fails=2fail_timeout=30s; 
        server   10.10.141.30:8081 weight=1max_fails=2fail_timeout=30s; 
        server   10.10.141.31:8080 weight=1max_fails=2fail_timeout=30s; 
        server   10.10.141.31:8081 weight=1max_fails=2fail_timeout=30s; 
        server   10.10.141.32:8080 weight=1max_fails=2fail_timeout=30s; 
        server   10.10.141.32:8081 weight=1max_fails=2fail_timeout=30s; 
    } 
    #这里为后端APP应用负载均衡配置,根据后端实际情况修改即可。tdt_app为负载均衡名称,可以任意指定
    upstream server_app { 
        server   10.10.141.40:8080 weight=1max_fails=2fail_timeout=30s; 
        server   10.10.141.40:8081 weight=1max_fails=2fail_timeout=30s; 
        server   10.10.141.41:8080 weight=1max_fails=2fail_timeout=30s; 
        server   10.10.141.41:8081 weight=1max_fails=2fail_timeout=30s; 
        server   10.10.141.42:8080 weight=1max_fails=2fail_timeout=30s; 
        server   10.10.141.42:8081 weight=1max_fails=2fail_timeout=30s; 
    } 
    #include引用vhosts.conf,该文件主要用于配置Nginx 虚拟主机  
    include vhosts.conf; 
    } 

如上nginx.conf配置完毕,继续配置nginx虚拟主机,继续在当前目录创建vhosts.conf
vi vhosts.conf 内容如下:

    #www.web.cn 
    server 
      { 
        listen       80; 
        server_name  www.web.cn; 
        index index.html index.htm; 
        #配置发布目录为/data/www/web
        root  /data/www/web;
 
        location / 
        { 
             proxy_next_upstream http_502 http_504 error timeout invalid_header; 
             proxy_set_header Host  $host; 
             proxy_set_header X-Real-IP $remote_addr; 
             proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
             proxy_pass http://server_web; 
             expires      3d; 
        } 

        #动态页面交给http://server_web,也即我们之前在nginx.conf定义的upstream server_web 均衡
        location ~ .*\.(do|php|jsp|cgi)?$ 
        { 
             proxy_set_header Host  $host; 
             proxy_set_header X-Real-IP $remote_addr; 
             proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
             proxy_pass http://server_web; 
        } 

        #配置Nginx动静分离,定义的静态页面直接从Nginx发布目录读取。
        location ~ .*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$ 
        { 
            root /data/www/web;
            #expires定义用户浏览器缓存的时间为3天,如果静态页面不常更新,可以设置更长,这样可以节省带宽和缓解服务器的压力
            expires      3d; 
        } 

        #定义Nginx输出日志的路径
        access_log  /data/logs/nginx_web/access.log main; 
        error_log   /data/logs/nginx_web/error.log  crit; 
    } 


      #www.app.cn 2016-10-20 
      server 
      { 
        listen       80; 
        server_name  www.app.cn; 
        index index.html index.htm; 
        root  /data/www/app; 

        location / 
        { 
             proxy_next_upstream http_502 http_504 error timeout invalid_header; 
             proxy_set_header Host  $host; 
             proxy_set_header X-Real-IP $remote_addr; 
             proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
             proxy_pass http://server_app; 
             expires      3d; 
        } 

        location ~ .*\.(php|jsp|cgi)?$ 
        { 
             proxy_set_header Host  $host; 
             proxy_set_header X-Real-IP $remote_addr; 
             proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 
             proxy_pass http://server_app; 
        } 

        location ~ .*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$ 
        { 
            root /data/www/app; 
            expires      3d; 
        } 
        access_log  /data/logs/nginx_app/access.log main; 
        error_log   /data/logs/nginx_app/error.log  crit; 
    } 

六、部署测试:
后端配置好Tomcat服务,并启动,发布的程序需同步到Nginx的/data/www对应的目录,因为配置动静分离后,用户请求你定义的静态页面,默认会去nginx的发布目录请求,而不会到后端请求,所以这时候你要保证后端跟前端的程序保持一致,可以使用Rsync做服务端自动同步。

    #检查Nginx配置文件是否配置正确,提示Ok and successful表示正确,如下:  
    [root@WEB-11-151 ~]# /usr/local/nginx/sbin/nginx -t 
    nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok 
    nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful

    #启动Nginx服务 
    /usr/local/nginx/sbin/nginx 

    #查看Nginx进程是否启动 
    ps -ef |grep nginx  

本文只是一个简单的实际案例,里面的配置和参数这里没有做过多的说明,后期会继续更新。

雷雷

这个人太懒什么东西都没留下

文章评论(0)

(Spamcheck Enabled)