SpringBoot2 使用Spring Session叢集

Java菜分享發表於2019-04-09

有幾種辦法:

1.擴充套件指定server

利用Servlet容器提供的外掛功能,自定義HttpSession的建立和管理策略,並通過配置的方式替換掉預設的策略。缺點:耦合Tomcat/Jetty等Servlet容器,不能隨意更換容器。

2.利用Filter

利用HttpServletRequestWrapper,實現自己的 getSession()方法,接管建立和管理Session資料的工作。spring-session就是通過這樣的思路實現的。

3 利用spring session

Spring Boot中spring session支援方式:

JDBC、MongoDB、Redis、Hazelcast、HashMap

一、引入maven依賴


<properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.session</groupId>
            <artifactId>spring-session-data-redis</artifactId>
        </dependency>
        
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
    </dependencies>
複製程式碼


二、配置application.properties


server.port=8080
spring.redis.host=localhost
spring.redis.port=6379
# spring session使用儲存型別
spring.session.store-type=redis
複製程式碼


  • spirngboot預設就是使用redis方式,如果不想用可以填none。、

三、在啟動類中加入@EnableRedisHttpSession 註解


package com.shyroke;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cache.annotation.EnableCaching;
import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;
@EnableCaching
@EnableRedisHttpSession  
@SpringBootApplication
public class SpringbootSessionApplication {
    public static void main(String[] args) {
        SpringApplication.run(SpringbootSessionApplication.class, args);
    }
}
複製程式碼


四、編寫控制器


package com.shyroke.controller;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.http.HttpRequest;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
@RequestMapping(value = "/")
public class IndexController {
    @ResponseBody
    @RequestMapping(value = "/session")
    public Map<String, Object> getSession(HttpServletRequest request) {
        request.getSession().setAttribute("username", "admin");
        Map<String, Object> map = new HashMap<String, Object>();
        map.put("sessionId", request.getSession().getId());
        return map;
    }
    @ResponseBody
    @RequestMapping(value = "/get")
    public String get(HttpServletRequest request) {
        String userName = (String) request.getSession().getAttribute("username");
        return userName;
    }
}
複製程式碼


五、測試

  • 先輸入http://localhost:8080/session,在session中設定一個值


SpringBoot2 使用Spring Session叢集


  • http://localhost:8080/get,獲取session中的值


SpringBoot2 使用Spring Session叢集


  • 複製這個工程,application.properties中的server.port=8081,然後訪問“http://localhost:8081/get”,如下獲取到了另一個工程中設定的session的值。

SpringBoot2 使用Spring Session叢集


原始碼面前,了無祕密

歡迎工作一到五年的Java工程師朋友們加入Java程式設計師開發: 721575865

群內提供免費的Java架構學習資料(裡面有高可用、高併發、高效能及分散式、Jvm效能調優、Spring原始碼,MyBatis,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多個知識點的架構資料)合理利用自己每一分每一秒的時間來學習提升自己,不要再用"沒有時間“來掩飾自己思想上的懶惰!趁年輕,使勁拼,給未來的自己一個交代!


相關文章