nginx+tomcat+redis的集群+session共享

本文介绍了如何配置Nginx、Tomcat和Redis以实现集群环境并进行Session共享。首先,详细讲述了安装Redis过程中遇到的异常及解决办法,包括安装gcc、jemalloc依赖和tcl。接着,部署Nginx,包括下载、安装和配置。最后,讲解了在Tomcat中使用Redis进行Session管理,下载相关jar包并修改context.xml以实现Session共享。

环境准备

1.tomcat版本:tomcat7

       tomcat下载及安装,目前很多好的资源和步骤,此处省略。

2.jdk版本:jdk1.7

       jdk下载及安装,目前很多好的资源和步骤,此处省略。

3.redis版本以及下载地址、安装步骤

wget http://download.redis.io/redis-stable.tar.gz
tar xvzf redis-stable.tar.gz
cd redis-stable
make

前面3步应该没有问题,主要的问题是执行make的时候,出现了异常。
异常一:
make[2]: cc: Command not found
异常原因:没有安装gcc
解决方案:yum install gcc-c++

异常二:
zmalloc.h:51:31: error: jemalloc/jemalloc.h: No such file or directory
异常原因:一些编译依赖或原来编译遗留出现的问题
解决方案:make distclean。清理一下,然后再make。

在make成功以后,需要make test。在make test出现异常。

异常一:
couldn't execute "tclsh8.5": no such file or directory
异常原因:没有安装tcl
解决方案:yum install -y tcl。

在make成功以后,会在src目录下多出一些可执行文件:redis-server,redis-cli等等。
方便期间用cp命令复制到usr目录下运行。
cp redis-server /usr/local/bin/
cp redis-cli /usr/local/bin/

然后新建目录,存放配置文件

mkdir /etc/redis
mkdir /var/redis
mkdir /var/redis/log
mkdir /var/redis/run
mkdir /var/redis/6379
 
在redis解压根目录中找到配置文件模板,复制到如下位置。
cp redis.conf /etc/redis/6379.conf
通过vim命令修改(默认的也可以,但上面已经创建了目录,最好操作这个步骤)
daemonize yes

pidfile /var/redis/run/redis_6379.pid
logfile /var/redis/log/redis_6379.log
dir /var/redis/6379

最后运行redis:

$ redis-server /etc/redis/6379.conf

 

注意:如果redis放在服务器上,并且需要让与redis不在同一台服务器的应用访问时,需要注释掉conf文件中的

bind 127.0.0.1为#bind 127.0.0.1,默认是bind 127.0.0.1(即不注释的)

4.ngnix的下载、安装、配置等步骤

1.下载地址:
下载:
加入指定存放的目录(如/home/software/ngnix)后执行下载命令,wget http://nginx.org/download/nginx-1.7.8.tar.gz
2.安装
解压:tar -zxvf nginx-1.7.8.tar.gz
执行 ./configure->make->make install等命令
3.开启ngnix
/usr/local/nginx-1.7.8/sbin/nginx
重启或关闭进程:
/usr/local/nginx-1.7.8/sbin/nginx -s reload
/usr/local/nginx-1.7.8/sbin/nginx -s stop
输入地址如:http://localhost/,如果出现欢迎使用ngnix,说明已经安装成功。

5.配置tomcat集群

1.到此为止环境都已经准备好,下面开始编写项目,并配置相关集群

修改nginx.conf加上:

upstream backend {  
    server 10.10.49.23:8080 max_fails=1 fail_timeout=10s;  
    server 10.10.49.15:8081 max_fails=1 fail_timeout=10s;  
}  

修改nginx.conf的location成

<ol style="font-size: 13px; padding: 0px; margin: 0px 0px 10px 25px; color: rgb(119, 119, 119); font-family: "Helvetica Neue", Helvetica, Arial, sans-serif; line-height: 20px;"><pre name="code" class="html">location / {  
    root   html;  
    index  index.html index.htm;  
    proxy_pass http://backend;  
 }  
    
    


    启动nginx。

     

    下载tomcat-redis-session-manager相应的jar包,主要有三个:

    wget https://github.com/downloads/jcoleman/tomcat-redis-session-manager/tomcat-redis-session-manager-1.2-tomcat-7-java-7.jar
    wget http://central.maven.org/maven2/redis/clients/jedis/2.5.2/jedis-2.5.2.jar
    wget http://central.maven.org/maven2/org/apache/commons/commons-pool2/2.0/commons-pool2-2.0.jar

    下载完成后拷贝到$TOMCAT_HOME/lib中

    修改两tomcat的context.xml:

    <Context>  
      
        <!-- Default set of monitored resources -->  
        <WatchedResource>WEB-INF/web.xml</WatchedResource>  
      
        <!-- Uncomment this to disable session persistence across Tomcat restarts -->  
        <!-- 
        <Manager pathname="" /> 
        -->  
      
        <!-- Uncomment this to enable Comet connection tacking (provides events  
             on session expiration as well as webapp lifecycle) -->  
        <!-- 
        <Valve className="org.apache.catalina.valves.CometConnectionManagerValve" /> 
        -->  
      
      <Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />  
      <Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager"  
       host="10.10.49.20"  
       port="6379"  
       password="123456"<!-- 如果没有密码,则不用设置此项-->
       database="0"  
       maxInactiveInterval="60" />  
    </Context>  

    下面为运行结果,2结果对比,不断的刷新可以看出后面的一串数字(sessionId)不会发生变化,而端口号不断的来回切换

    这说明,用户每次访问的都是同一个会话(sessionid没有变化)。

    评论
    成就一亿技术人!
    拼手气红包6.0元
    还能输入1000个字符
     
    红包 添加红包
    表情包 插入表情
     条评论被折叠 查看
    添加红包

    请填写红包祝福语或标题

    红包个数最小为10个

    红包金额最低5元

    当前余额3.43前往充值 >
    需支付:10.00
    成就一亿技术人!
    领取后你会自动成为博主和红包主的粉丝 规则
    hope_wisdom
    发出的红包
    实付
    使用余额支付
    点击重新获取
    扫码支付
    钱包余额 0

    抵扣说明:

    1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
    2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

    余额充值