session共享原理和配置

一、session共享原理

在负载均衡的模式下开发,会在不同的服务器上进行访问,因此同一个客户端不同的请求可能会产生不同的session,就会产生多次登录的现象。因此需要session共享,此处我们使用redis将session存储的形式。

二、sesion共享配置

(1)需要两个tomcat,并配置不同的端口号
        分别在tomcat1的conf→server.xml中配置
       1. <Server port="18005" shutdown="SHUTDOWN">
       2.<Connector port="18080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
       3. <Connector port="18009" protocol="AJP/1.3" redirectPort="8443" />
         分别在tomcat2的conf→server.xml中配置
       1. <Server port="28005" shutdown="SHUTDOWN">
       2.<Connector port="28080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />
       3. <Connector port="28009" protocol="AJP/1.3" redirectPort="8443" />

(2)在tomcat的webapps ROOT下建立一个向session写数据的,一个从session得到数据和session的JSP文件
(3)将jedis-2.5.2.jar
      commons-pool.jar
      tomcat-redis-session-manager-2.0.0.jar
     全部拷贝到两个tomcat的lib下面(这几个包重写的tomcat的底层session实现机制)
(4)在两个tomcat的conf下面的context.xml中加入如下代码
     <Valve className="com.orangefunction.tomcat.redissessions.RedisSessionHandlerValve" />

    <Manager className="com.orangefunction.tomcat.redissessions.RedisSessionManager"
    host="localhost"//redis的地址
    port="6379"//redis的端口
    database="0"//redis的数据库,选择哪个数据库
    maxInactiveInterval="60" />
(5)两个tomcat启动,启动ngnix,启动redis
(6)此时在浏览器中可以输入localhost:18080/write.jsp
                        localhost:18080/read.jsp
(7)此时在浏览器中可以输入localhost:28080/write.jsp
                        localhost:28080/read.jsp
此时得到的是相同的session
    

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章