您好,登錄后才能下訂單哦!
本篇內容介紹了“如何用spring+redis實現session共享”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
使用Nginx+Tomcat進行負載均衡時,希望使用輪詢方式進行負載。但是如果使用輪詢方式的話,可能會訪問不同的Tomcat,此時如果不進行Session共享,則相當于是一個新的Session。就比如現有系統都是需要認證登錄的系統,如果沒有Session共享,則會導致用戶退出登錄
目前實現 session 共享的方式有以下幾種:
1、使用Tomcat內置的Session復制方案
只適合Tomcat小集群,不適合大集群,因為session復制是all to all的方式
2、使用第三方(個人)基于Tomcat實現的Session管理
第三方支持,支持力度不夠,尤其是不能提供對Tomcat8的支持
3、使用Spring Session實現
本文介紹的是第三種解決辦法,即使用 spring session + redis 的方案
<!-- 使用Spring Session來解決Session共享問題 --> <dependency> <groupId>org.springframework.session</groupId> <artifactId>spring-session-data-redis</artifactId> <version>1.3.0.RELEASE</version> <type>pom</type> </dependency> <dependency> <groupId>biz.paluch.redis</groupId> <artifactId>lettuce</artifactId> <version>3.5.0.Final</version> </dependency> <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>2.9.0</version> </dependency>
在web.xml中加入以下過濾器,注意如果web.xml中有其他過濾器,一般情況下Spring Session的過濾器要放在第一位
<filter> <filter-name>springSessionRepositoryFilter</filter-name> <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class> </filter> <filter-mapping> <filter-name>springSessionRepositoryFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
<context:property-placeholder location="classpath:redis.properties" ignore-unresolvable="true"/> <bean id="redisHttpSessionConfiguration" class="org.springframework.session.data.redis.config.annotation.web.http.RedisHttpSessionConfiguration"> <property name="maxInactiveIntervalInSeconds" value="600"/> </bean> <bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig"> <property name="maxTotal" value="50" /> <property name="maxIdle" value="10" /> <property name="testOnBorrow" value="false" /> </bean> <bean id="jedisConnectionFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory" destroy-method="destroy"> <property name="hostName" value="${redis.ip}"/> <property name="port" value="${redis.port}"/> <property name="password" value="${redis.password}" /> <property name="timeout" value="3000"/> <property name="usePool" value="true"/> <property name="poolConfig" ref="jedisPoolConfig"/> </bean>
redis.ip=127.0.0.1 redis.port=6379 redis.password=123456
寫一個 請求方法 轉發到 session_share.jsp
@RequestMapping("/session") public String session(HttpSession session, HttpServletRequest request){ request.setAttribute("id", request.getSession().getId()); return "session_share"; }
接著 編寫 session_share.jsp
tomcat1 <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>session共享</title> </head> <body> 1 我的session:${id} <br>sessionid=<%=session.getId()%> </body> </html> ------------------------------------------------------- tomcat2 <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>session共享</title> </head> <body> 2 我的session:${id} <br>sessionid=<%=session.getId()%> </body> </html>
upstream load_balance_server { #weigth參數表示權值,權值越高被分配到的幾率越大 server 192.168.0.131:8080 weight=1; server 192.168.0.167:8090 weight=1; } server { listen 80; server_name localhost; #charset koi8-r; #access_log logs/host.access.log main; location / { proxy_pass http://load_balance_server; index dashboard index; proxy_set_header Host $http_host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header X-Forwarded-Proto $scheme; } }
nginx 所在 IP 為 192.168.0.131
連續多次訪問 192.168.0.131:80/session 頁面上的 sessionId 沒有發生變化 , 1 和 2 在不停切換
“如何用spring+redis實現session共享”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。