ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
使用redis共享tomcat多节点session,需要安装redis、nginx、tomcat6以及用于tomcat存储session到redis的jar包:tomcat-redis-session-manager-1.2-tomcat-6.jar、 commons-pool-1.6.jar、jedis-2.1.0.jar等。这些jar包、配置文件及demo程序可以在最后的demo地址中下载。 下面是对tomcat、nginx进行配置及运行: ### 1.把demo包中的jar包拷贝到tomcat的lib目录中: ### 2.配置tomcat的context.xml文件: ~~~ <Valve className="com.radiadesign.catalina.session.RedisSessionHandlerValve"/>; <Manager className="com.radiadesign.catalina.session.RedisSessionManager" host="localhost" port="6379" database="0" maxInactiveInterval="60"/>; ~~~ ### 3.配置tomcat的server.xml: ~~~ 对于不同的tomcat,以下几个port配置成不同的值如: tomcat1: <Server port="8007" shutdown="SHUTDOWN"> <Connector port="18080" protocol="org.apache.coyote.http11.Http11Protocol" connectionTimeout="20000" redirectPort="8444" /> <Connector port="8019" protocol="AJP/1.3" redirectPort="8444" /> <Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat1"> tomcat2: <Server port="8008" shutdown="SHUTDOWN"> <Connector port="18081" protocol="org.apache.coyote.http11.Http11Protocol" connectionTimeout="20000" redirectPort="8445" /> <Connector port="8029" protocol="AJP/1.3" redirectPort="8445" /> <Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat2"> ~~~ ### 4.配置nginx集群: ~~~ 对nginx.conf进行配置: upstream tomcat { server 127.0.0.1:18080; server 127.0.0.1:18081; } server { listen 8080; server_name 127.0.0.1; location / { proxy_redirect off; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; client_max_body_size 10m; client_body_buffer_size 128k; proxy_buffers 32 4k; proxy_connect_timeout 3; proxy_send_timeout 30; proxy_read_timeout 30; proxy_pass http://tomcat; } } ~~~ ### 5.把demo.war程序放入到tomcatde webapps中: 修改demo中的index.jsp中的内容,不同的tomcat中,内容不一样。如下: ~~~ tomcat1中的demo: tomcat1:<%=session.getId() %> tomcat2中的demo: tomcat2:<%=session.getId() %> ~~~ ### 6.启动nginx,redis、tomcat1、tomcat2: 打开浏览器,输入地址:http://localhost:8081/demo ### 7.按F5刷新页面: 我们可以看到页面,不管我们怎么刷新,只有前面的tomcat的标识发生变化,而后面的sessionID是固定的如下: ~~~ tomcat1:8EA77B42358EFC1CD1F5FBC7246A1317.tomcat1 tomcat2:8EA77B42358EFC1CD1F5FBC7246A1317.tomcat1 ~~~ 如果出现以上的结果说明共享session成功了,如果大家在尝试过程中出现什么问题,可以给我留言。 ### 8.demo下载地址: [使用redis在nginx负载下tomcat6多节点共享session  ](http://download.csdn.net/detail/mr_smile2014/9364603)