最近在学习tomcat集群,看了网上有好几种方案,一般都是apache+tomcat+tomcat session共享或者ngnix+tomcat+tomcat session共享。介绍ngnix+tomcat+redis的还是比较少,在查找了各种博客之后终于搭建起了一个简单的tomcat自动负载均衡的例子。由于目前还没有搭建起来redis集群,所以redis一旦挂掉session也就全部消失了。我搞定后在发一篇博客。
本次的系统环境为linux系统,windows用户也可以参考一下。
首先下载tomcat7.0.47 http://tomcat.apache.org/download-70.cgi
到下载文件夹下解压tomcat到 /usr/local/tomcats中并复制3份,分别命名为tomcat1 , tomcat2 , tomcat3。
#解压tomcat [root@data1 Downloads]# tar zxvf apache-tomcat-7.0.47.tar.gz #复制到tomcats文件夹下 [hadoop@data1 Downloads]# sudo cp -rf apache-tomcat-7.0.47 /usr/local/tomcats/tomcat_a [hadoop@data1 Downloads]# sudo cp -rf apache-tomcat-7.0.47 /usr/local/tomcats/tomcat_b [hadoop@data1 Downloads]# sudo cp -rf apache-tomcat-7.0.47 /usr/local/tomcats/tomcat_c
tomcat解压好以后,对3个tomcat都配置环境变量(前提是你已经搭建好了java环境 如果没有请参考我的文章 http://zhangqiaoqifgdqsn.iteye.com/blog/1974649)
#使用gedit打开profile 你也可以用vi 或者 vim 打开 [hadoop@data1 Downloads]$ sudo gedit /etc/profile #tomcat a 的配置 #tomcat a classpath export TOMCAT_A_HOME=/usr/local/tomcats/tomcat_a export CATALINA_A_HOME=/usr/local/tomcats/tomcat_a export CATALINA_A_BASE=/usr/local/tomcats/tomcat_a export CLASSPATH=$TOMCAT_A_HOME/common/lib/servlet.jar:$CLASSPATH export PATH=$CATALINA_A_HOME/lib:$PATH #tomcat b 的配置 #tomcat b classpath export TOMCAT_B_HOME=/usr/local/tomcats/tomcat_b export CATALINA_B_HOME=/usr/local/tomcats/tomcat_b export CATALINA_B_BASE=/usr/local/tomcats/tomcat_b export CLASSPATH=$TOMCAT_B_HOME/common/lib/servlet.jar:$CLASSPATH export PATH=$CATALINA_B_HOME/lib:$PATH #tomcat c 的配置 #tomcat c classpath export TOMCAT_C__HOME=/usr/local/tomcats/tomcat_c export CATALINA_C_HOME=/usr/local/tomcats/tomcat_c export CATALINA_C_BASE=/usr/local/tomcats/tomcat_c export CLASSPATH=$TOMCAT_C_HOME/common/lib/servlet.jar:$CLASSPATH export PATH=$CATALINA_C_HOME/lib:$PATH
因为是3的tomcat在一台机子上模拟集群,所以要把tomcat的端口全部更改,以免在tomcat启动的时候报端口错误。
#修改以下端口号使得不冲突就OK,自己设定。 #修改服务端口 <Server port="8005" shutdown="SHUTDOWN"> #http访问端口 <Connector port="8080" protocol="HTTP/1.1"> #AJP端口 <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
解压 nginx-1.4.3.tar.gz , 并编译nginx(所有用到的包在我的上传文件中)
#解压nginx以及需要用到的依赖包 [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 进入nginx并编译文件 [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 #查看是否安装成功 [root@localhost ~]# ll /usr/local/nginx/ drwxr-xr-x 2 root root 4096 Sep 24 15:12 conf drwxr-xr-x 2 root root 4096 Sep 24 15:12 html drwxr-xr-x 2 root root 4096 Sep 24 15:12 logs drwxr-xr-x 2 root root 4096 Sep 24 15:12 sbin #测试Nginx配置文件是否正确 [root@localhost ~]#/usr/local/nginx/sbin/nginx –t #启动nginx [root@localhost ~]#/usr/local/nginx/sbin/nginx
在浏览器里输入localhost查看nginx是否开启
使用nginx的http代理访问实现tomcat的负载均衡:这里主要修改nginx的配置文件nginx.conf
user nobody; worker_processes 4; error_log logs/error.log; events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout 65; gzip on; #设定负载均衡的服务器列表 upstream localhost { #weigth参数表示权值,权值越高被分配到的几率越大 server 192.168.56.12:8881 weight=1; #对应tomcat_a server 192.168.56.12:5556 weight=1; #对应tomcat_b server 192.168.56.12:9233 weight=1; #对应tomcat_c } server { listen 80; server_name localhost; charset utf-8; location / { root html; index index.html index.htm; proxy_pass http://localhost; proxy_set_header X-Real-IP $remote_addr; client_max_body_size 100m; } location ~ ^/(WEB-INF)/ { deny all; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } }
更改tomcat的index.jsp的内容 验证tomcat是否实现了负载均衡
<!-- 将开头的session = "false" 改为true --> <%@ page session="true" %> <!-- 在body的div下添加获取session id 和 tomcat标识--> <body> <div id="wrapper"> <font>tomcat_aaa</font><%=session.getId()%> <!-- 修改完上面内容保存并退出 其他两个tomcat重复上面步骤-->
做完上面操作之后,启动tomcat a b c nginx 在浏览器中输入localhost,F5刷新测试,tomcat是否交替访问
然后是Redis的安装和配置
#解压redis [root@localhost ~] # tar xvzf redis-stable.tar.gz #编译redis [root@localhost ~] # cd redis-stable/ [root@localhost redis-stable] # make && make install #到src目录下 [root@localhost redis-stable] # cd redis-stable/src #启动redis [root@localhost src] # ./redis-server --port 6379
将tomcat需要调用redis需要的jar包放入tomcat_a _b _c lib文件夹下(commons-pool-1.6.jar commons-pool2-2.0.jar jedis-2.1.0.jar tomcat-redis-session-manager-1.2-tomcat-7-java-7-jar)这些jar包我都放在文章下面共享了。
最后我们在tomcat a b c 中config下的context.xml下配置如下内容就可以了
<Valve className="com.radiadesign.catalina.session.RedisSessionHandlerValve" /> <Manager className="com.radiadesign.catalina.session.RedisSessionManager" host="localhost" port="6379" database="0" maxInactiveInterval="60" />
然后启动tomcat a b c ngnix 查看是否实现了负载均衡,session共享
OK搞完收工 嘿嘿
相关推荐
有小白看着都可以照做的文档及说明。已经有session的包,所使用的Tomcat版本为 7.0.62 ,比网上其它的说明详细很多。
自己做的一个nginx+tomcat+redis完成session共享小例子,包括所需jar,适合初学者,希望大家一起学习交流
2个tomcat8+nginx+2个redis(主从同步)+同步会话
nginx+tomcat+redis集群部署环境,包括nginx tomcat redis及集群部署所需jar包,jedis-2.6.1.jar,commons-pool2-2.2.jar,tomcat-redis-session-manager1.2.jar 具体步骤可以参见我的博文
目前只支持tomcat8.5,其它版本的tomcat还没测试,自己配置过很多nginx+tomcat集群+redis实现session共享的系统,经过仔细总结得出这些,可以说是知识的结晶,欢迎大家来下载,不好的地方可以多提,有问题看到的话会...
apache-tomcat-7.0.67+nginx-1.14.0+Redis-x64-3.2.6379集群部署所需JAR包
男孩的天职nginx+tomcat集群+redis存储session 下载的是一个pdf文件,文件里面有视频演示下载地址,以及jdk1.8 tomcat8 nginx 1.8安装笔记,绝对可以用 nginx反向代理tomcat集群,请求轮训给集群的tomcat,session...
nginx1.8.1+tomcat7.0+redis3.2.100+redisManage 集群配置文件,内含tomcat-redis-session-manager1.2.jar(含jedis和commonspool2) session共享采用redis。
Tomcat+Nginx+Redis搭建高性能负载均衡集群Session共享
Nginx+Redis+Tomcat 集群部署文档以及所需jar包和Nginx+Redis+Tomcat安装包
超详细Nginx+Tomcat+Redis搭建高性能负载均衡集群Session共享搭建说明,按文档步骤可轻松搭建并实现session共享
第2章 Tomcat集群 2 2.1 Tomcat集群架构 2 2.1.1 Nginx服务器 2 2.1.2 Tomcat服务器 3 2.1.3 数据库服务器 3 2.1.4 Redis服务器 3 2.2 服务器配置说明 3 第3章 集群的安装与配置 5 3.1 JDK的安装和配置 5 ...
tomcat8+Redis+nginx负载均衡集群部署,apache-tomcat-8.0.47+nginx-1.13.6+Redis-x64-3.2.100
nginx+redis负载均衡、session共享,基于redis+tomcat实现session同步的简单demo
分布式web server集群部署后需要实现session共享,针对 tomcat 服务器的实现方案多种多样,比如 tomcat cluster session 广播、nginx IP hash策略、nginx sticky module等方案,本文主要介绍了使用 redis 服务器进行...
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-...
基于ssm+shiro+redis+nginx tomcat服务器集群管理项目 基于ssm+shiro+redis+nginx tomcat服务器集群管理项目 基于ssm+shiro+redis+nginx tomcat服务器集群管理项目 基于ssm+shiro+redis+nginx tomcat服务器集群管理...
https://blog.csdn.net/milkbrother1988/article/details/96422896
本实例基于nginx+tomcat+redis的集群实现,实现session的复制。压缩包内含两个tomcat+一个nginx服务器+64位windows版的redis+说明文档,下载即可运行,详细步骤可以参考文档,从此告别集群盲区
通过nginx+keepalived+tomcat实现服务器负载均衡的高可用方案,解决传统负载均衡服务器宕机后无法自行切换从而导致雪崩效应的场景