当前位置: 首页 > news >正文

分布式集群Session缓存丢失问题


> 本文首发于CSDN:分布式集群Session缓存丢失问题
#### 前言

    Session缓存共享的背景和意义:通常我们搭建完集群之后,不得不考虑的一个问题就是用户访问产生的session如何处理。如果不做任何处理的话,用户将出现频繁登录的现象,比如集群中存在A、B两台服务器,用户在第一次访问网站时,Nginx通过其负载均衡机制将用户请求转发到A服务器,这时A服务器就会给用户创建一个Session。当用户第二次发送请求时,Nginx将其负载均衡到B服务器,而这时候B服务器并不存在Session,所以就会将用户踢到登录页面。这将大大降低用户体验度,导致用户的流失,这种情况是项目绝不应该出现的。


尤其是在大型分布式集群web项目中,必须得处理和解决Session缓存共享机制的问题,接下来讨论几种常见的Session缓存丢失的解决方案:


#### 一、Ip_Hash

ip_hash方法,这个可谓是最为简单的方法了,我们在硬件和软件(程序侵入)上无需做出优化和改变;只需在负载均衡软件设备的配置文件中设置好就行了。目前三大主流软件负载均衡器如:LVS、Nginx、HAproxy;我们以Nginx为例。


它的原理是:用户(客户端)在请求服务器之前,均需要经过Nginx进行反向转发路由;那么配置了ip_hash均衡权重后,Nginx会根据客户端请求的ip地址进行哈希算法映射到某台服务器,只要该用户访问请求的ip地址不发生变更,服务器的设备也不变化,那么之后该用户每次访问的请求豆浆固定到这太服务器上。如:A B两台服务器,用户1经ip_hash映射到A之后,那么之后每次请求都将不变的映射到机器A。


优点:简单,不需要对session做任何处理。


缺点:缺乏容错性,如果当前访问的服务器发生故障,用户被转移到第二个服务器上时,他的session信息都将失效。


适用场景:发生故障对客户产生的影响较小;服务器发生故障是低概率事件。


实现方式:以Nginx为例,在upstream模块配置ip_hash属性即可实现粘性Session。


`upstream mycluster{
#这里添加的是上面启动好的两台Tomcat服务器
ip_hash;#粘性Session
server 192.168.22.229:8080 weight=1;
server 192.168.22.230:8080 weight=1;
}
`
另:Nginx有3种常见均衡权重配置(轮询(默认)、ip_hash、指定权重(自定义分配))。


#### 二、服务器session复制

原理:任何一个服务器上的session发生改变(增删改),该节点会把这个 session的所有内容序列化,然后广播给所有其它节点,不管其他服务器需不需要session,以此来保证Session同步。


优点:可容错,各个服务器间session能够实时响应。


缺点:会对网络负荷造成一定压力,如果session量大的话可能会造成网络堵塞,拖慢服务器性能。


实现方式:




![](https://i-blog.csdnimg.cn/blog_migrate/8358ea247867b37488c5617d31324ca3.png)

session复制



应用服务器开启Web容器的session的复制功能,在集群中的几台服务器之间同步session对象,这样一台服务器宕机不会导致session数据丢失。即每一台服务器都持有集群中所有的session,每次访问仅从本机获取就可以了。


从session复制的几条线就可以看出,这种方式仅适用用小型集群。当服务集群规模很大时,集群服务器间的复制就需要大量的通讯,占用大量网络资源,甚至会出现内存不够的情况。


#### 三、统一Session缓存(共享机制)

第三种方法,也是最具有优势和大厂经常被采用的一种方案。尤其是大型分布式架构的系统,这种方案的优势非常的突出。使用分布式缓存方案比如memcached、Redis,但是要求Memcached或redis必须是集群。本文以Redis为例讲述Session共享机制。

- 配置Filter过滤拦截器,拦截Session

`
springSessionRepositoryFilter
org.springframework.web.filter.DelegatingFilterProxy


springSessionRepositoryFilter
/*
`

- 经过Redis或Memcache再缓存
- 防止在Session中的对象必须是可序列化的
- SpringSessionRepositoryFilter的顺序必须在其他获取Session的filter之前
- Session的失效时间由Redis节点过期时间决定,原有配置无效



![](https://i-blog.csdnimg.cn/blog_migrate/6d4b1aaa0e2915127aed7eb1833241be.png)

Session统一缓存



优点:某个应用服务器出现问题,session不会丢失;对服务器的配置性能要求最低级,轻松实现高并发访问;对程序无侵入性。


缺点:缓存Session的memcached或Redis一旦挂掉,则session丢失。


 


综上:一般大型分布式系统,首选第三种(统一Session缓存)Session共享机制。


 




![](https://i-blog.csdnimg.cn/blog_migrate/5b60928520d25864171476043193d190.jpeg)

同名原创公众号:
程序大视界



 





$(function() {
setTimeout(function () {
var mathcodeList = document.querySelectorAll('.htmledit_views img.mathcode');
if (mathcodeList.length > 0) {
for (let i = 0; i ');
curSpan.text(alt);
$(mathcodeList[i]).before(curSpan);
$(mathcodeList[i]).remove();
}
} else {
mathcodeList[i].onerror = function() {
var alt = mathcodeList[i].alt;
alt = '\\(' + alt + '\\)';
var curSpan = $('');
curSpan.text(alt);
$(mathcodeList[i]).before(curSpan);
$(mathcodeList[i]).remove();
};
}
}
MathJax.Hub.Queue(["Typeset",MathJax.Hub]);
}
}, 500)
});




![](https://csdnimg.cn/release/blogv2/dist/pc/img/vip-limited-close-newWhite.png)

确定要放弃本次机会?

福利倒计时


:

:




![](https://csdnimg.cn/release/blogv2/dist/pc/img/vip-limited-close-roup.png)
立减 ¥

普通VIP年卡可用

立即使用





![

程序大视界

](https://blog.csdn.net/Follow_24)


关注
关注



-

![](https://csdnimg.cn/release/blogv2/dist/pc/img/tobarThumbUpactive.png)
![](https://csdnimg.cn/release/blogv2/dist/pc/img/toolbar/like-active.png)
![](https://csdnimg.cn/release/blogv2/dist/pc/img/toolbar/like.png)

1


点赞

-

![](https://csdnimg.cn/release/blogv2/dist/pc/img/toolbar/unlike-active.png)
![](https://csdnimg.cn/release/blogv2/dist/pc/img/toolbar/unlike.png)



-
[
![](https://csdnimg.cn/release/blogv2/dist/pc/img/toolbar/collect-active.png)
![](https://csdnimg.cn/release/blogv2/dist/pc/img/toolbar/collect.png)
![](https://csdnimg.cn/release/blogv2/dist/pc/img/newCollectActive.png)

2

](javascript:;)



收藏





觉得还不错?

一键收藏

![](https://csdnimg.cn/release/blogv2/dist/pc/img/collectionCloseWhite.png)


-

![](https://csdnimg.cn/release/blogv2/dist/pc/img/guideRedReward01.png)
知道了

[
![](https://csdnimg.cn/release/blogv2/dist/pc/img/toolbar/comment.png)

0

](#commentBox)
评论

-
[
![](https://csdnimg.cn/release/blogv2/dist/pc/img/toolbar/share.png)
分享
](javascript:;)



复制链接


分享到 QQ


分享到新浪微博




![](https://csdnimg.cn/release/blogv2/dist/pc/img/share/icon-wechat.png)扫一扫




-
[
![](https://csdnimg.cn/release/blogv2/dist/pc/img/toolbar/reward.png)
打赏
](javascript:;)
打赏

-

![](https://csdnimg.cn/release/blogv2/dist/pc/img/toolbar/more.png)





![](https://csdnimg.cn/release/blogv2/dist/pc/img/toolbar/reward.png)
打赏


![](https://csdnimg.cn/release/blogv2/dist/pc/img/toolbar/report.png)
举报




![](https://csdnimg.cn/release/blogv2/dist/pc/img/toolbar/report.png)
举报

http://www.jsqmd.com/news/772266/

相关文章:

  • BitRouter:为AI智能体构建高性能智能路由与安全代理层
  • 3分钟上手ChanlunX:零基础实现缠论自动化分析的终极方案
  • 超强项目脚手架Cookiecutter:告别重复代码编写的终极指南
  • Lime3DS游戏截图与录像功能:高质量游戏内容创作终极指南
  • 彻底搞懂最小生成树算法:从概念到实战的完整指南
  • **靠谱的餐饮线上营销怎么选2026指南,本地生活平台精准引流与私域复购率提升策略** - 品牌企业推荐师(官方)
  • Ripes终极指南:如何通过可视化仿真彻底掌握RISC-V处理器架构
  • 终极指南:electron-react-boilerplate架构设计揭秘,打造企业级跨平台桌面应用的最佳实践
  • 如何用MobileSAM与Inpaint-Anything实现高效图像修复:完整实战指南
  • SpringCloud+MyBatis(oracle)逆向工程自动生成代码
  • River时间序列预测终极指南:从Holt-Winters到SNARIMAX的完整教程
  • 2026深圳黄金回收避坑指南:认准这几家正规门店最放心 - 品牌企业推荐师(官方)
  • ComfyUI IPAdapter Plus终极实战:专业级多模型图像生成方案
  • 3分钟解锁Android TV遥控器新姿势:免费虚拟鼠标工具终极指南
  • 谱华检测|成都CMA权威第三方,用精准数据守护蓉城呼吸健康 - 品牌企业推荐师(官方)
  • 如何用MTKClient拯救变砖的联发科设备:从诊断到修复的实战指南
  • CookieCutter命令行工具:所有参数用法详解终极指南
  • 极简信息聚合器Nas4146/brief:用Python+Docker打造你的私人简报机器人
  • 终极指南:使用homemade-machine-learning实现机器学习系统健康监测与异常检测
  • JSP页面+Servlet乱码问题解决方法
  • 5步在PC上运行任天堂Switch游戏:Ryujinx模拟器完全指南
  • LayaAir音视频处理:打造沉浸式游戏体验的完整方案
  • radare2自动化脚本:批量处理二进制文件的终极指南
  • Needle实战案例:TicTacToe项目依赖注入完整实现
  • Python Web开发实战:构建现代Web应用
  • 充电桩销售厂家口碑推荐:靠谱货源哪里找? - 品牌企业推荐师(官方)
  • JBoss应用服务器清理缓存
  • 5步打造你的高品质音乐收藏:TIDAL-dl-ng开源工具完全指南
  • WarcraftHelper终极指南:让你的魔兽争霸3在现代电脑上重生
  • Flink实时数据处理终极指南:从零构建企业级流处理系统