`

linux系统通过nginx实现tomcat集群

 
阅读更多
[摘要]集群是由两台或多台节点机(服务器)构成的一种松散耦合的计算节点集合,为用户提供网络服务或应用程序(包括数据库、Web服务和文件服务等)的单一客户视图,同时提供接近容错机的故障恢复能力。本文介绍的是在linux系统下使用nginx环境实现tomcat集群。

  集群系统一般通过两台或多台节点服务器系统通过相应的硬件及软件互连,每个群集节点都是运行其自己进程的独立服务器。

  这些进程可以彼此通信,对网络客户机来说就像是形成了一个单一系统,协同起来向用户提供应用程序、系统资源和数据。除了作为单一系统提供服务,集群系统还具有恢复服务器级故障的能力。而tomcat集群这是可以做到以上几点。

  首先,安装nginx之前需要pcre依赖和jvm-remote补丁。

一、准备如下软件:

1、nginx-1.1.2.tar.gz,负载均衡/反向代理服务器,可通过http://nginx.org/en/download.html获取。
2、pcre-8.10.tar.gz,正规表达式库,可通过http://sourceforge.net/projects/pcre/获取;
3、nginx-upstream-jvm-route-0.1.tar.gz,是一个 Nginx 的扩展模块,用来实现基于 Cookie 的 Session Sticky 的功能,可通过http://code.google.com/p/nginx-upstream-jvm-route/downloads/list获取;

二、安装和安装

1、解压各软件

[root@localhost ~]# tar zxvf pcre-8.10.tar.gz
[root@localhost ~]# tar zxvf nginx-upstream-jvm-route-0.1.tar.gz
[root@localhost ~]# tar nginx-1.1.2.tar.gz

2、安装

[root@localhost ~]# cd nginx-1.1.2
[root@localhost ~]# patch -p0 < ${nginx-upstream-jvm-route解压目录}/jvm_route.patch
[root@localhost ~]# ./configure --prefix=/usr/local/nginx --with-pcre=${pcre解压目录} --with-http_stub_status_module --with-http_ssl_module --add-module=${nginx-upstream-jvm-route解压目录}
[root@localhost ~]# make
[root@localhost ~]# make install

三、修改配置

1、修改tomcat的server.xml,服务器的tomcat的配置文件中分别找到:
<Engine name="Catalina" defaultHost="localhost" >
分别修改为:

Tomcat01:
<Engine name="Catalina" defaultHost="localhost" jvmRoute="a">
Tomcat02:
<Engine name="Catalina" defaultHost="localhost" jvmRoute="b">
Tomcat03:
<Engine name="Catalina" defaultHost="localhost" jvmRoute="c">

2、修改nginx的nginx.conf文件

#运行NGINX所使用的用户和组
user  root;
#nginx进程数,建议按照cpu数目来指定,一般为它的倍数,每个进程消耗约10M内存
worker_processes  1;
 
#日志信息
error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;
 
pid        logs/nginx.pid;
 
events {
    #使用epoll的I/O模型
    use epoll;
    #该值受系统进程最大打开文件数限制,需要使用命令ulimit -n 查看当前设置
    worker_connections 24;
}
 
 
http {
    #这里是您需要修改的地方,修改为您的服务器IP:端口号 srun_id为您在tomcat中所配置的jvmRoute
    upstream backend{
      server2.168.12.128:18080 srun_id=a;
      server2.168.12.128:28080 srun_id=b;
      server2.168.12.128:38080 srun_id=c;
      jvm_route $cookie_JSESSIONID|sessionid reverse;
    }
    include       mime.types;
    #设置默认类型是二进制流,若未设置时,比如未加载PHP时,是不予解析,用浏览器访问则出现下载窗口
    default_type application/octet-stream;
    charset UTF-8;
    server_names_hash_bucket_size8;
    client_header_buffer_sizek;
    large_client_header_buffers 4k;
    client_max_body_sizem;
    limit_rate24k;
    sendfile on;
    tcp_nopush     on;
    keepalive_timeout;
    tcp_nodelay on;
    fastcgi_connect_timeout0;
    fastcgi_send_timeout0;
    fastcgi_read_timeout0;
    fastcgi_buffer_sizek;
    fastcgi_buffers 4k;
    fastcgi_busy_buffers_size8k;
    fastcgi_temp_file_write_size8k;
    gzip on;
    #gzip_min_length 1k;
    gzip_buffers     4k;
    gzip_http_version 1.0;
    gzip_comp_level 2;
    gzip_types       text/plain application/x-javascript text/css application/xml;
    gzip_vary on;
    #limit_zone crawler $binary_remote_addrm;
    server {
        listen      ;
        server_name 2.168.12.128; #这里也是您所需要修改的地方,多域名用空格隔开
        index index.html index.htm index.jsp;
        charset UTF-8;
        root /usr/local/tomcats/project/;# 这里也是您所需要修改的地方,虚拟机指向的路径(可能这里有点问题),我的web应用系统放在project下面的
        #access_log  logs/host.access.log  main;
         
        #这里也是您所需要修改的地方,yourproject更换成您的项目路径
        location /yourproject/ {
            proxy_pass http://backend;
            proxy_redirect off;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header Host $http_host;
            index  index.html index.htm index.jsp;
        }
        location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ {
            expiresd;
        }
        location ~ .*\.(js|css)?$ {
            expires 1h;
        }
        location /Nginxstatus{
            stub_status on;
            access_log off;
        }
        log_format access '$remote_addr - $remote_user [$time_local] "$request" '
             '$status $body_bytes_sent "$http_referer" '
             '"$http_user_agent" $http_x_forwarded_for';
 
        error_page 4              /404.html;
 
        error_page  0234  /50x.html;
        location = /50x.html {
            root   html;
        }
    }
}

3、检查nginx的配置

[root@localhost ~]# /usr/local/nginx/sbin/nginx -t -c /usr/nginx/conf/nginx.conf

四、启动测试

/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
/usr/local/tomcats/tomcat-a/bin/startup.sh
/usr/local/tomcats/tomcat-b/bin/startup.sh
/usr/local/tomcats/tomcat-c/bin/startup.sh

停止服务

/usr/local/tomcats/tomcat-a/bin/shutdown.sh
/usr/local/tomcats/tomcat-b/bin/shutdown.sh
/usr/local/tomcats/tomcat-c/bin/shutdown.sh
pkill -9 nginx



我的配置文件
#运行NGINX所使用的用户和组

user  root;

#nginx进程数,建议按照cpu数目来指定,一般为它的倍数,每个进程消耗约10M内存

worker_processes  1;



#日志信息

error_log  logs/error.log;

#error_log  logs/error.log  notice;

#error_log  logs/error.log  info;



pid        logs/nginx.pid;



events {

    #使用epoll的I/O模型

    use epoll;

    #该值受系统进程最大打开文件数限制,需要使用命令ulimit -n 查看当前设置

    worker_connections  1024;

}





http {

    #这里是您需要修改的地方,修改为您的服务器IP:端口号 srun_id为您在tomcat中所配置的jvmRoute

    upstream backend{

      server 121.199.43.119:18080 srun_id=a;

      server 121.199.43.119:28080 srun_id=b;

      server 121.199.43.119:38080 srun_id=c;

      jvm_route $cookie_JSESSIONID|sessionid reverse;

    }

    include       mime.types;

    #设置默认类型是二进制流,若未设置时,比如未加载PHP时,是不予解析,用浏览器访问则出现下载窗口

    default_type application/octet-stream;

    charset UTF-8;

    server_names_hash_bucket_size 128;

    client_header_buffer_size 32k;

    large_client_header_buffers 4 32k;

    client_max_body_size 20m;

    limit_rate 1024k;

    sendfile on;

    tcp_nopush     on;

    keepalive_timeout 60;

    tcp_nodelay on;

    fastcgi_connect_timeout 300;

    fastcgi_send_timeout 300;

    fastcgi_read_timeout 300;

    fastcgi_buffer_size 64k;

    fastcgi_buffers 4 64k;

    fastcgi_busy_buffers_size 128k;

    fastcgi_temp_file_write_size 128k;

    gzip on;

    #gzip_min_length 1k;

    gzip_buffers     4 16k;

    gzip_http_version 1.0;

    gzip_comp_level 2;

    gzip_types       text/plain application/x-javascript text/css application/xml;

    gzip_vary on;

    #limit_zone crawler $binary_remote_addr 10m;

    server {

        listen       80;

        server_name  121.199.43.119; #这里也是您所需要修改的地方,多域名用空格隔开

        index index.html index.htm index.jsp;

        charset UTF-8;

        root /usr/local/nginx/html/;# 这里也是您所需要修改的地方,虚拟机指向的路径(可能这里有点问题),我的web应用系统放在project下面的

        #access_log  logs/host.access.log  main;



        #这里也是您所需要修改的地方,yourproject更换成您的项目路径

        location / {

            proxy_pass http://backend;

            proxy_redirect off;

            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

            proxy_set_header X-Real-IP $remote_addr;

            proxy_set_header Host $http_host;

            index  index.html index.htm index.jsp;

        }

        location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ {

            expires 30d;

        }

        location ~ .*\.(js|css)?$ {

            expires 1h;

        }

        location /Nginxstatus{

            stub_status on;

            access_log off;

        }

        log_format access '$remote_addr - $remote_user [$time_local] "$request" '

             '$status $body_bytes_sent "$http_referer" '

             '"$http_user_agent" $http_x_forwarded_for';



        error_page  404              /404.html;



        error_page   500 502 503 504  /50x.html;

        location = /50x.html {

            root   html;

        }

    }

}


分享到:
评论

相关推荐

    linux环境下通过nginx实现tomcat集群.pdf

    在Linux环境中,通过Nginx实现Tomcat集群是一项常见的高可用性和负载均衡配置技术。Nginx作为反向代理服务器,可以将用户的请求分发到多个Tomcat实例上,从而提高系统的处理能力和容错性。以下是一份详细的步骤指南...

    linux环境下通过nginx实现tomcat集群借鉴.pdf

    在Linux环境下,通过Nginx实现Tomcat集群是一项常见的技术实践,可以提高Web应用的可用性和性能。Nginx作为反向代理和负载均衡器,可以将来自客户端的请求分发到多个Tomcat实例上,实现负载均衡。以下将详细阐述这个...

    Linux系统nginx+tomcat集群方案

    Linux系统nginx+tomcat集群方案在三台虚拟机上经过测试成功!

    linux下nginx-tomcat集群及 memecached session共享

    linux下nginx-tomcat集群及session共享,亲测成功,下载的文件包含了所有需要的jar包及nginx,memcached安装,配置,由于试了很多种方法,下了很多包,有些也需要积分,所以这里下载要些积分留着用,不好意思了,...

    Liunx 下 nginx+tomcat 集群建设

    总结来说,Linux环境下通过Nginx+Tomcat集群建设,可以构建出一个高效、可扩展的Web服务架构,同时利用Nginx的反向代理功能和负载均衡策略,确保系统的稳定性和性能。在实际操作中,还需要根据具体业务需求进行定制...

    linux下的nginx+tomcat负载均衡简单原理

    Linux 下的 Nginx+Tomcat 负载均衡简单原理是指通过 Nginx 服务器来实现 Tomcat 服务器集群的负载均衡,以提高网站的可用性和性能。本文将对 Linux 下的 Nginx+Tomcat 负载均衡简单原理进行详细的介绍。 一、拓扑...

    linux nginx tomcat 集群搭建

    这个过程涉及到的知识点包括Linux系统管理、Nginx配置、Tomcat集群设置以及源码编译。 首先,Nginx是一款高性能的HTTP和反向代理服务器,常用于处理静态内容和作为负载均衡器,将请求分发到后端不同的服务器。Nginx...

    nginx+tomcat集群

    【Nginx+Tomcat集群】是常见的Java Web服务架构,这种组合利用Nginx作为前端反向代理服务器,负责接收客户端请求,并将这些请求分发到后端多个Tomcat实例,实现负载均衡,提高系统可用性和响应速度。以下是详细的...

    nginx+tomcat负载、集群简单搭建

    通过本文介绍的方法,可以简单地在Windows环境下实现Nginx+Tomcat的负载均衡和集群搭建。这对于初学者来说是一个很好的入门实践,有助于理解和掌握负载均衡和集群的基本原理和技术要点。当然,在生产环境中还需要...

    Docker-Compose部署nginx代理Tomcat集群

    Docker是一个开源的应用容器引擎,它允许开发者打包他们的应用及其依赖环境到一个可移植的容器中,然后发布到任何流行的Linux或Windows机器上,也可以实现虚拟化。而Docker Compose是Docker的一个工具,用于定义和...

    nginx+tomcat+redis完成session共享

    这个小例子"nginx+tomcat+redis完成session共享"旨在演示如何通过这三种技术实现跨服务器的用户会话共享,以提升用户体验并简化系统管理。以下是这些技术及其在会话共享中的作用: 1. **Nginx**:Nginx是一款高性能...

    Keepalived+Nginx+Tomcat 高可用集群搭建实战记录

    Keepalived 是一种高可用性解决方案,可以与 Nginx 和 Tomcat 配合使用来实现高可用集群。下面是 Keepalived+Nginx+Tomcat 高可用集群搭建的实战记录。 Keepalived 简介 Keepalived 是一种基于 Linux 的高可用性...

    tomcat+nginx集群

    在集群环境中,多个Tomcat实例可以并行运行,通过Nginx进行负载均衡,提高服务的响应能力和容错性。 集群部署时,Nginx通常配置为反向代理服务器,它接收来自Internet的请求,然后将这些请求转发到后端的Tomcat实例...

    Nginx+Tomcat负载均衡企业实战.docx

    * Nginx 负载均衡 Tomcat 集群的实现 * 动静分离的实现 * Rewrite 实战的实现 五、结语 本文档提供了从 0 开始构建 Nginx WEB 平台、Tomcat WEB 集群、代码发布、Nginx 负载均衡 Tomcat 集群、动静分离、Rewrite ...

    linux安装nginx和tomcat

    ### Linux下安装Nginx与Tomcat集群 在Linux环境下部署Web应用时,通常会用到Nginx作为反向代理服务器以及Tomcat作为应用服务器。本文将详细介绍如何在Linux系统上安装Nginx和Tomcat,并搭建一个简单的集群。 #### ...

    nginx + tomcat集群搭建

    通过以上步骤,我们成功地构建了一个基于Nginx + Tomcat集群的高性能Web服务架构。这种架构不仅提高了系统的并发处理能力,还通过负载均衡和session共享解决了单点故障的问题,极大地提升了用户体验和服务的稳定性。...

    keepalived+Nginx+tomcat 搭建集群

    在 Linux 系统中,通常通过包管理器(如 apt-get 或 yum)进行安装,然后使用 `systemctl start nginx` 启动服务。 2.3 Nginx 目录结构 Nginx 的目录结构通常包括 `conf`(配置文件)、`logs`(日志文件)、`sbin`...

    nginx tomcat集群 session复制

    本文将详细介绍如何在Nginx和Tomcat集群中实现Session复制。 ### 一、测试环境搭建 1. **软件列表**: - Nginx - PCRE (Perl Compatible Regular Expressions) - Nginx-upstream-jvm-route (用于处理Java路由) ...

Global site tag (gtag.js) - Google Analytics