一、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