设为首页 收藏本站
查看: 1405|回复: 0

[经验分享] tomcat集群 nginx+tomcat+redis 单机模拟

[复制链接]

尚未签到

发表于 2016-12-20 08:18:36 | 显示全部楼层 |阅读模式
    最近在学习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 
DSC0000.jpg
 
    到下载文件夹下解压tomcat到 /usr/local/tomcats中并复制3份,分别命名为tomcat1 , tomcat2 , tomcat3。
 

#解压tomcat
[iyunv@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.iyunv.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以及需要用到的依赖包
[iyunv@localhost ~]# tar zxvf pcre-8.10.tar.gz
[iyunv@localhost ~]# tar zxvf nginx-upstream-jvm-route-0.1.tar.gz
[iyunv@localhost ~]# tar nginx-1.1.2.tar.gz
进入nginx并编译文件
[iyunv@localhost ~]# cd nginx-1.1.2
[iyunv@localhost ~]# patch -p0 < ${nginx-upstream-jvm-route解压目录}/jvm_route.patch
[iyunv@localhost ~]# ./configure --prefix=/usr/local/nginx \
--with-pcre=${pcre解压目录} \
--with-http_stub_status_module \
--with-http_ssl_module \
--add-module=${nginx-upstream-jvm-route解压目录}
[iyunv@localhost ~]# make(此处可能要很长时间,请耐心等待)
[iyunv@localhost ~]# make install
#查看是否安装成功
[iyunv@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配置文件是否正确
[iyunv@localhost ~]#/usr/local/nginx/sbin/nginx –t   
#启动nginx     
[iyunv@localhost ~]#/usr/local/nginx/sbin/nginx      
 
     在浏览器里输入localhost查看nginx是否开启
  
DSC0001.jpg
     使用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是否交替访问
  
DSC0002.jpg
 
DSC0003.jpg
    然后是Redis的安装和配置
 

#解压redis
[iyunv@localhost ~] # tar xvzf redis-stable.tar.gz
#编译redis
[iyunv@localhost ~] # cd redis-stable/
[iyunv@localhost redis-stable] # make && make install
#到src目录下
[iyunv@localhost redis-stable] # cd redis-stable/src  
#启动redis
[iyunv@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共享
 
  
DSC0004.jpg
 
DSC0005.jpg
 
DSC0006.jpg
 
 
    OK搞完收工 嘿嘿
 

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-316653-1-1.html 上篇帖子: 《Redis源码学习笔记》数据结构-字典 下篇帖子: 基于redis分布式缓存实现(转)
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表