SpringBoot之使用Spring Session集群-redis
用nginx做负载的时候,会出现每一次http请求都会分配到不同的tomcat上,这样用session存储用户数据就会有问题。因为tomcat集群之间没有实现session共享。
spring-session跟redis很好的帮我们解决了这个问题。
一、引入maven依赖
01 |
<? xml version = "1.0" encoding = "UTF-8" ?> |
04 |
< modelVersion >4.0.0</ modelVersion > |
06 |
< groupId >com.cicoding.druid</ groupId > |
07 |
< artifactId >springboot_session_redis_colony</ artifactId > |
08 |
< version >0.0.1-SNAPSHOT</ version > |
09 |
< packaging >war</ packaging > |
11 |
< name >springboot_session_redis_colony</ name > |
12 |
< description >Demo project for Spring Boot</ description > |
15 |
< groupId >org.springframework.boot</ groupId > |
16 |
< artifactId >spring-boot-starter-parent</ artifactId > |
17 |
< version >1.5.9.RELEASE</ version > |
22 |
< project.build.sourceEncoding >UTF-8</ project.build.sourceEncoding > |
23 |
< project.reporting.outputEncoding >UTF-8</ project.reporting.outputEncoding > |
24 |
< java.version >1.8</ java.version > |
29 |
< groupId >org.springframework.boot</ groupId > |
30 |
< artifactId >spring-boot-starter-data-redis</ artifactId > |
33 |
< groupId >org.springframework.session</ groupId > |
34 |
< artifactId >spring-session-data-redis</ artifactId > |
38 |
< groupId >org.springframework.boot</ groupId > |
39 |
< artifactId >spring-boot-starter-web</ artifactId > |
46 |
< groupId >org.springframework.boot</ groupId > |
47 |
< artifactId >spring-boot-maven-plugin</ artifactId > |
二、配置application.properties
server.port=8082
spring.redis.host=localhost
spring.redis.port=6379
spring.redis.password=redis password
# spring session使用存储类型
spring.session.store-type=redis
- spirngboot默认就是使用redis方式,如果不想用可以填none。
三、在启动类中加入@EnableRedisHttpSession 注解
package com.cicoding;
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 SessionApplication {
public static void main(String[] args) {
SpringApplication.run(SessionApplication.class, args);
}
}
四、编写控制器
package com.cicoding.controller;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
@RequestMapping(value = "/")
public class UserController {
@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;
}
}
五、测试