- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
分布式Session共享
概念
不同进程之间的session共享访问。
解决了分布式系统或者系统集群部署时出现的问题: web容器(如tomcat)管理的session都存放于本地内存中无法共享,用户每次访问的服务器可能都不一样,因此出现服务器不能识别用户、用户登录状态失效等。
解决方案:
方案一:黏性session
NGINX等负载均衡网关,可以通过hash映射等方式,保证相同用户的请求会转发到同一台服务器。
优点:简单高效,易实施。
缺点:存在大量请求转发到单点服务器极端情况导致负载均衡失效;单点故障导致用户session丢失。
方案二:tomcat集群session复制
Tomcat提供集群环境下的session复制功能,以达到session共享。
优点:无开发工作量。
缺点:session复制会消耗大量服务器资源,只能应用于小规模的集群。
方案三:Spring session + redis(推荐)
Spring session可以接管web容器的session管理,并可以将session数据存放于redis等第三方存储。
优点:Spring boot/cloud项目无缝集成;可存储海量session数据;可以利用redis提供的持久化保证宕机恢复、服务升级重启用户session不丢失;很好的支持服务在线扩容!
缺点:Spring session没有多语言版本,限制了微服务框架下不同的技术选型。
Spring boot/cloud下的使用方法:
增加配置redis和spring session的配置
spring.redis.host=spring.redis.password=123456spring.redis.port=6379spring.session.store-type=redis
创建配置类,开启注解
@Configuration@EnableRedisHttpSessionpublic class UserCenterSessionConfig { @Bean public JedisConnectionFactory connectionFactory(){ return new JedisConnectionFactory(); }}
Spring Cloud微服务项目中存在如下情况,导致session共享失效:
Zuul做API网关,转发时默认禁止传递Cookie。需要开启Cookie传递。
# zuul默认的zuul.sensitive-headers配置将过滤请求header的Cookie、Set-Cookie、Authorization三个属性,导致cookie无法传播。
# 敏感头信息设置为空zuul.sensitive-headers=
Feigin整合Hystrix,仿RPC调用其他微服务接口。最终请求的发送是由另一个Hystrix线程完成的,与Feign不在同一个线程,导致请求头信息丢失,Cookie传递失败。需要做请求拦截,手动添加。
@Configurationpublic class FeignConfig { @Bean public RequestInterceptor requestInterceptor(){ return new RequestInterceptor() { @Override public void apply(RequestTemplate requestTemplate) { String sessionId = RequestContextHolder.currentRequestAttributes().getSessionId(); requestTemplate.header(Cookie, SESSION= + sessionId); } }; }}
您可能关注的文档
- 培训学校保密制度.doc
- 培训学校-教务管理-教学事故认定及处理意见.docx
- 培养良好的 预习习惯.ppt
- 培养良好的学习习惯1206175.ppt
- 培训开班仪式讲话.doc
- 培训班学员行为规范.doc
- 培训管理制度(含流程图).doc
- 培训管理(PPT 38页).ppt
- 培训课件--门店销售服务技巧-OK.ppt
- 培训与开发ppt.ppt
- 2025年福建五建集团第一批公开招聘项目制人员52人笔试备考试题附答案.docx
- 2025年房地产经纪人土地使用年限的起算时间点确定专题试卷及解析.pdf
- 2025年石城县卫生健康总院公开选调农村订单定向本科医学生8人备考题库附答案.docx
- 2025年石台县部分事业单位公开招聘工作人员13人备考题库附答案.docx
- 2025年公务员面试应急应变题型及解答试卷.docx
- 2025年福州国有资本投资运营集团有限公司社会公开招聘12人公笔试备考试题最新.docx
- 2025年福建三明建宁县绥城建设集团有限公司招聘3人笔试备考试题最新.docx
- 2025年石家庄市市属国有企业公开招聘应届毕业生223人笔试备考试题附答案.docx
- 2025年福建五建集团第一批公开招聘项目制人员52人笔试参考题库最新.docx
- 2025年盘锦客运公交集团面向社会公开招聘工作人员24人笔试备考试题附答案.docx
原创力文档


文档评论(0)