這次帶來的是spring boot + redis 實現(xiàn)session共享的教程。
在spring boot的文檔中,告訴我們添加@EnableRedisHttpSession來開啟spring session支持,配置如下:
@Configuration
@EnableRedisHttpSession
public class RedisSessionConfig {
}
而@EnableRedisHttpSession這個注解是由spring-session-data-redis提供的,所以在pom.xml文件中添加:
org.springframework.boot
spring-boot-starter-redis
org.springframework.session
spring-session-data-redis
接下來,則需要在application.properties中配置redis服務器的位置了,在這里,我們就用本機:
spring.redis.host=localhost
spring.redis.port=6379
這樣以來,最簡單的spring boot + redis實現(xiàn)session共享就完成了,下面進行下測試。
首先我們開啟兩個tomcat服務,端口分別為8080和9090,在application.properties中進行設置【下載地址】 :
server.port=8080
接下來定義一個Controller:
@RestController
@RequestMapping(value = "/admin/v1")
public class QuickRun {
@RequestMapping(value = "/first", method = RequestMethod.GET)
public Map
Map
request.getSession().setAttribute("request Url", request.getRequestURL());
map.put("request Url", request.getRequestURL());
return map;
}
@RequestMapping(value = "/sessions", method = RequestMethod.GET)
public Object sessions (HttpServletRequest request){
Map
map.put("sessionId", request.getSession().getId());
map.put("message", request.getSession().getAttribute("map"));
return map;
}
}
啟動之后進行訪問測試,首先訪問8080端口的tomcat,返回 獲取【下載地址】 :
{"request Url":":8080/admin/v1/first"}
接著,我們訪問8080端口的sessions,返回:
{"sessionId":"efcc85c0-9ad2-49a6-a38f-9004403776b5","message"::8080/admin/v1/first}
最后,再訪問9090端口的sessions,返回:
{"sessionId":"efcc85c0-9ad2-49a6-a38f-9004403776b5","message"::8080/admin/v1/first}
可見,8080與9090兩個服務器返回結(jié)果一樣,實現(xiàn)了session的共享
如果此時再訪問9090端口的first的話,首先返回:
{"request Url":":9090/admin/v1/first"}
而兩個服務器的sessions都是返回:
{"sessionId":"efcc85c0-9ad2-49a6-a38f-9004403776b5","message":":9090/admin/v1/first"}
通過spring boot + redis來實現(xiàn)session的共享非常簡單,而且用處也極大,配合nginx進行負載均衡,便能實現(xiàn)分布式的應用了。
本次的redis并沒有進行主從、讀寫分離等等配置(_(:з」∠)_其實是博主懶,還沒嘗試過.......)
而且,nginx的單點故障也是我們應用的障礙......以后可能會有對此次博客的改進版本,比如使用zookeeper進行負載均衡,敬請期待。