因为Http协议是无状态的协议,导致服务器并不知道你来了几次,无法识别用户。
于是出现了两种保持Http状态的技术,那就是Cookie和Session。
解决方案
1 Nginx的 IP_Hash 策略
在nginx的配置文件(nginx.conf),在负载均衡的配置加:
ip_hash;
如图:
效果:
同一个客户端IP的请求都会被路由到同一个目标服务器,也叫做会话粘滞
优点:
配置简单,不入侵应用,不需要额外修改代码
缺点:
服务器重启Session丢失
存在单点负载高的风险
单点故障问题
第二种方案: Session共享,Session集中存储(推荐使用)
基于Redis的Session共享,
Spring Session使得基于Redis的Session共享应用起来非常之简单。
优点:
- 能适应各种负载均衡策略
- 服务器重启或者宕机不会造成Session丢失
- 扩展能力强
- 适合大集群数量使用
缺点:
- 对应用有入侵,引用了和Redis的交互代码
应用:
1)引入Jar
<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>```
2)配置redis
spring.redis.database=0
spring.redis.host=127.0.0.1
spring.redis.port=6379
`
3)添加注解
在启动类加如下注解:
@EnableRedisHttpSession
这样就可以实现session共享啦!