您好,登錄后才能下訂單哦!
這次帶來的是spring boot + redis 實現(xiàn)session共享的教程。
在spring boot的文檔中,告訴我們添加@EnableRedisHttpSession來開啟spring session支持,配置如下:
@Configuration
@EnableRedisHttpSession
public class RedisSessionConfig {
}
而@EnableRedisHttpSession這個注解是由spring-session-data-redis提供的,所以在pom.xml文件中添加:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-redis</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.session</groupId>
<artifactId>spring-session-data-redis</artifactId>
</dependency>
接下來,則需要在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<String, Object> firstResp (HttpServletRequest request){
Map<String, Object> map = new HashMap<>();
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<String, Object> map = new HashMap<>();
map.put("sessionId", request.getSession().getId());
map.put("message", request.getSession().getAttribute("map"));
return map;
}
}
啟動之后進行訪問測試,首先訪問8080端口的tomcat,返回 獲取【下載地址】 :
{"request Url":"http://localhost:8080/admin/v1/first"}
接著,我們訪問8080端口的sessions,返回:
{"sessionId":"efcc85c0-9ad2-49a6-a38f-9004403776b5","message":"http://localhost:8080/admin/v1/first"}
最后,再訪問9090端口的sessions,返回:
{"sessionId":"efcc85c0-9ad2-49a6-a38f-9004403776b5","message":"http://localhost:8080/admin/v1/first"}
可見,8080與9090兩個服務器返回結果一樣,實現(xiàn)了session的共享
如果此時再訪問9090端口的first的話,首先返回:
{"request Url":"http://localhost:9090/admin/v1/first"}
而兩個服務器的sessions都是返回:
{"sessionId":"efcc85c0-9ad2-49a6-a38f-9004403776b5","message":"http://localhost:9090/admin/v1/first"}
通過spring boot + redis來實現(xiàn)session的共享非常簡單,而且用處也極大,配合nginx進行負載均衡,便能實現(xiàn)分布式的應用了。
本次的redis并沒有進行主從、讀寫分離等等配置(_(:з」∠)_其實是博主懶,還沒嘗試過.......)
而且,nginx的單點故障也是我們應用的障礙......以后可能會有對此次博客的改進版本,比如使用zookeeper進行負載均衡,敬請期待。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。