linux系统通过nginx实现tomcat集群

  • 时间:
  • 浏览:0
  • 来源:3分快3网投平台-5分11选5投注平台_5分3D娱乐平台
作者:匿名 hihi 来源:ChinaZ源码报导 浏览: 2011-9-22 10:28:41 字号:大 中 小

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

  集群系统一般通过两台或多台节点服务器系统通过相应的硬件及软件互连,每个群集节点都有运行其本人任务管理器运行运行的独立服务器。

  有有哪些任务管理器运行运行还需用彼此通信,对网络客户机来说就像是形成了另另另一有1个 单一系统,协同起来向用户提供任务管理器运行运行、系统资源和数据。除了作为单一系统提供服务,集群系统还具有恢复服务器级故障的能力。而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,是另另另一有1个 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:1200200 srun_id=a;

server2.168.12.128:2200200 srun_id=b;

server2.168.12.128:3200200 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 /200x.html;



location = /200x.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
sssss
Tags: linux   nginx   tomcat   tomcat集群  
责任编辑:190