91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何用spring+redis實現session共享

發布時間:2021-07-02 16:02:12 來源:億速云 閱讀:171 作者:chen 欄目:大數據

本篇內容介紹了“如何用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 的方案

一、引入 pom 

<!-- 使用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中加入以下過濾器,注意如果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>

三、配置 spring-mvc.xml

<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.properties

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>

六、配置 nginx 負載均衡

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共享”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

云南省| 庆阳市| 封丘县| 虎林市| 含山县| 岳西县| 平顺县| 武威市| 荔波县| 惠水县| 鹿邑县| 崇仁县| 徐水县| 济源市| 同仁县| 丽水市| 马尔康县| 常州市| 陇西县| 翁牛特旗| 监利县| 大竹县| 台东县| 靖远县| 七台河市| 宣城市| 太谷县| 永和县| 浮山县| 白水县| 望谟县| 宜春市| 根河市| 工布江达县| 阿尔山市| 阿巴嘎旗| 南岸区| 阿坝| 寻乌县| 门头沟区| 沂南县|