zoukankan      html  css  js  c++  java
  • nginx+tomcat+redis的集群+session共享

    nginx+tomcat+redis的集群+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加上:

     

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

    修改nginx.conf的location成

     

    1. location / {  
    2.     root   html;  
    3.     index  index.html index.htm;  
    4.     proxy_pass http://backend;  
    5.  }  


    启动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:

     

    1. <Context>  
    2.   
    3.     <!-- Default set of monitored resources -->  
    4.     <WatchedResource>WEB-INF/web.xml</WatchedResource>  
    5.   
    6.     <!-- Uncomment this to disable session persistence across Tomcat restarts -->  
    7.     <!-- 
    8.     <Manager pathname="" /> 
    9.     -->  
    10.   
    11.     <!-- Uncomment this to enable Comet connection tacking (provides events  
    12.          on session expiration as well as webapp lifecycle) -->  
    13.     <!-- 
    14.     <Valve className="org.apache.catalina.valves.CometConnectionManagerValve" /> 
    15.     -->  
    16.   
    17.   <Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />  
    18.   <Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager"  
    19.    host="10.10.49.20"  
    20.    port="6379"  
    21.    password="123456"<!-- 如果没有密码,则不用设置此项-->
    22.    database="0"  
    23.    maxInactiveInterval="60" />  
    24. </Context>  


     

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

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

  • 相关阅读:
    Spring 学习7 -事务
    Spring学习 6- Spring MVC (Spring MVC原理及配置详解)
    看秒杀系统的时候看到的关于并发队列的介绍,摘抄如下
    Spring 学习 3- AOP
    Spring学习-1 框架总览
    Spring 学习 5- task 定时任务
    JAVA锁机制-可重入锁,可中断锁,公平锁,读写锁,自旋锁,
    指定链接的样式的顺序
    css方法实现div固定浏览器底端
    文件中批量搜索字符串
  • 原文地址:https://www.cnblogs.com/swite/p/5814992.html
Copyright © 2011-2022 走看看