這次帶來(lái)的是spring boot + redis 實(shí)現(xiàn)session共享的教程。
在spring boot的文檔中,告訴我們添加@EnableRedisHttpSession來(lái)開(kāi)啟spring session支持,配置如下:
@Configuration
@EnableRedisHttpSession
public class RedisSessionConfig {
}
而@EnableRedisHttpSession這個(gè)注解是由spring-session-data-redis提供的,所以在pom.xml文件中添加:
org.springframework.boot
spring-boot-starter-redis
org.springframework.session
spring-session-data-redis
接下來(lái),則需要在application.properties中配置redis服務(wù)器的位置了,在這里,我們就用本機(jī):
spring.redis.host=localhost
spring.redis.port=6379
這樣以來(lái),最簡(jiǎn)單的spring boot + redis實(shí)現(xiàn)session共享就完成了,下面進(jìn)行下測(cè)試。
首先我們開(kāi)啟兩個(gè)tomcat服務(wù),端口分別為8080和9090,在application.properties中進(jìn)行設(shè)置【下載地址】 :
server.port=8080
接下來(lái)定義一個(gè)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;
}
}
啟動(dòng)之后進(jìn)行訪問(wèn)測(cè)試,首先訪問(wèn)8080端口的tomcat,返回 獲取【下載地址】 :
{"request Url":":8080/admin/v1/first"}
接著,我們?cè)L問(wèn)8080端口的sessions,返回:
{"sessionId":"efcc85c0-9ad2-49a6-a38f-9004403776b5","message"::8080/admin/v1/first}
最后,再訪問(wèn)9090端口的sessions,返回:
{"sessionId":"efcc85c0-9ad2-49a6-a38f-9004403776b5","message"::8080/admin/v1/first}
可見(jiàn),8080與9090兩個(gè)服務(wù)器返回結(jié)果一樣,實(shí)現(xiàn)了session的共享
如果此時(shí)再訪問(wèn)9090端口的first的話,首先返回:
{"request Url":":9090/admin/v1/first"}
而兩個(gè)服務(wù)器的sessions都是返回:
{"sessionId":"efcc85c0-9ad2-49a6-a38f-9004403776b5","message":":9090/admin/v1/first"}
通過(guò)spring boot + redis來(lái)實(shí)現(xiàn)session的共享非常簡(jiǎn)單,而且用處也極大,配合nginx進(jìn)行負(fù)載均衡,便能實(shí)現(xiàn)分布式的應(yīng)用了。
本次的redis并沒(méi)有進(jìn)行主從、讀寫(xiě)分離等等配置(_(:з」∠)_其實(shí)是博主懶,還沒(méi)嘗試過(guò).......)
而且,nginx的單點(diǎn)故障也是我們應(yīng)用的障礙......以后可能會(huì)有對(duì)此次博客的改進(jìn)版本,比如使用zookeeper進(jìn)行負(fù)載均衡,敬請(qǐng)期待。