`
zhangqiaoqifgdqsn
  • 浏览: 14705 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

tomcat集群 nginx+tomcat+redis 单机模拟

 
阅读更多

    最近在学习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搞完收工 嘿嘿

 

  • 描述: download
  • 大小: 36.7 KB
  • 大小: 29.6 KB
  • 大小: 83.4 KB
  • 大小: 62.3 KB
  • 大小: 59.8 KB
  • 大小: 60.8 KB
  • 大小: 52.2 KB
分享到:
评论
2 楼 sdoq19 2015-03-05  
1 楼 kazaff 2014-10-23  
非常感谢~~

相关推荐

    keepalived+nginx+tomcat+redis+mysql所需的jdk包

    这个压缩包包含了"keepalived+nginx+tomcat+redis+mysql"所需的基础组件,特别是Java Development Kit(JDK)。下面我们将详细探讨这些组件及其在IT领域的应用。 首先,JDK是Java编程语言的基石,它提供了编译、...

    Nginx+tomcat+redis

    在构建高性能、高可用性的Web服务时,"Nginx+Tomcat+Redis"的组合是一种常见的架构模式。这个架构充分利用了每个组件的优势,以实现高效的数据处理、动态内容渲染和负载均衡。以下是对这套技术栈的详细解释: 1. **...

    Tomcat集群(Tomcat+nginx+redis)

    有小白看着都可以照做的文档及说明。已经有session的包,所使用的Tomcat版本为 7.0.62 ,比网上其它的说明详细很多。

    nginx+keepalived+tomcat+redis文档

    ### Nginx+Keepalived+Tomcat+Redis 高可用与负载均衡架构解析 #### 架构概览 为了确保Web服务器的稳定运行及高效处理能力,采用Nginx+Keepalived+Tomcat+Redis的技术组合进行系统构建。这一架构通过多个组件的...

    nginx+tomcat+redis完成session共享

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

    redis缓存服务器Nginx+Tomcat+redis+MySQL实现session会话共享

    "redis缓存服务器Nginx+Tomcat+redis+MySQL实现session会话共享"的主题旨在探讨如何利用这些技术组件来实现这一目标。以下是相关知识点的详细说明: **Redis**:Redis是一个高性能的键值数据存储系统,常用于做缓存...

    国产中标麒麟操作系统nginx+tomcat+redis+mysql安装部署手册(精).docx

    《国产中标麒麟操作系统Nginx+Tomcat+Redis集群安装部署手册》是针对在中标麒麟操作系统上搭建Web服务环境的详细指南。这份手册由东软集团股份有限公司于2019年12月编撰,旨在解决在实际部署过程中可能出现的各种...

    2个tomcat8+nginx+2个redis(主从同步)+同步会话

    在构建高可用、高并发的Web服务环境中,"2个tomcat8+nginx+2个redis(主从同步)+同步会话"的架构方案是一种常见的选择。这种方案结合了多种技术,以确保服务的稳定性和数据的一致性。以下是各个组成部分的详细说明: ...

    nginx+tomcat+redis集群部署环境

    nginx+tomcat+redis集群部署环境,包括nginx tomcat redis及集群部署所需jar包,jedis-2.6.1.jar,commons-pool2-2.2.jar,tomcat-redis-session-manager1.2.jar 具体步骤可以参见我的博文

    Nginx+Tomcat+Redis搭建均衡负载集群

    在构建高性能、高可用性的Web服务时,"Nginx+Tomcat+Redis"的组合是一种常见的架构模式。这个架构利用Nginx作为反向代理和负载均衡器,Tomcat作为Java应用服务器处理业务逻辑,而Redis则用作缓存系统以提升数据访问...

    nginx+tomcat+redis +redis客户端 等负载均衡资料

    在IT行业中,构建高效、可扩展的Web服务是至关重要的,而`nginx`、`tomcat`、`redis`和`redis客户端`等工具在这一过程中扮演着关键角色。这里我们将详细探讨这些技术及其在负载均衡中的应用。 首先,`nginx`是一款...

    nginx+tomcat集群+redis实现session共享

    目前只支持tomcat8.5,其它版本的tomcat还没测试,自己配置过很多nginx+tomcat集群+redis实现session共享的系统,经过仔细总结得出这些,可以说是知识的结晶,欢迎大家来下载,不好的地方可以多提,有问题看到的话会...

    tomcat-redis-session-manager tomcat+nginx+redis集群所需jar

    在Tomcat集群前部署Nginx,可以实现负载均衡,将用户请求分发到不同的Tomcat实例上,提高系统的响应速度和可用性。 3. **Redis**: Redis是一个内存中的数据结构存储系统,常用于做高速缓存和数据库。在这个场景中,...

    Keepalived+nginx+tomcat+redis_session_share

    - **配置Location**:在`server`部分为`/test`路径配置`Proxy_pass`指令,转发请求至Tomcat集群,并传递必要的头部信息。 #### 5. 安装与配置Keepalived - **安装Keepalived**:根据系统环境选择合适的安装方式,...

    男孩的天职nginx+tomcat集群+redis存储session

    男孩的天职nginx+tomcat集群+redis存储session 下载的是一个pdf文件,文件里面有视频演示下载地址,以及jdk1.8 tomcat8 nginx 1.8安装笔记,绝对可以用 nginx反向代理tomcat集群,请求轮训给集群的tomcat,session...

    nginx1.8.1+tomcat7.0+redis3.2.100+redisManage 集群配置文件

    nginx1.8.1+tomcat7.0+redis3.2.100+redisManage 集群配置文件,内含tomcat-redis-session-manager1.2.jar(含jedis和commonspool2) session共享采用redis。

    redis+tomcat+nginx负载均衡配置

    在构建高性能、高可用性的Web服务时,"redis+tomcat+nginx负载均衡配置"是一个常见且有效的架构模式。这个组合充分利用了各个组件的优势,确保系统稳定、响应快速,并能够处理大量的并发请求。以下是关于这个配置的...

    Redis+nginx集群部署

    **标题:Redis+nginx集群部署** **描述:**在本实践中,我们将结合Tomcat应用服务器、Nginx反向代理服务器以及Redis作为会话存储来建立一个高可用、负载均衡的Web集群。Nginx负责将用户请求分发到各个Tomcat实例,...

    Nginx+Tomcat+Redis搭建高性能负载均衡集群Session共享

    超详细Nginx+Tomcat+Redis搭建高性能负载均衡集群Session共享搭建说明,按文档步骤可轻松搭建并实现session共享

Global site tag (gtag.js) - Google Analytics