分布式session一致性问题
1.分布式session一致性 :指服务器集群情况下session共享的问题。
2.session的作用:保存服务器(tomcat)与客户端(浏览器)整个通讯的会话基本信息。
3.session应用场景:记录用户信息。登录场景(账号密码登陆成功之后,获取到userid,存放在session中,下次登录的时候直接从session中获取用户信息)、防止表单重复提交。
session可以理解为本地jvm缓存,session存放在服务器端,返回sessionid给客户端,客户端下一次请求根据sessionid去服务器端获取用户信息。
session原理:
session存放在哪里? 服务器端
浏览器关闭了,session会失效吗? 不会失效。
第一次请求:客户端向服务器端发送一个请求,服务器接收到客户端的请求,会创建一个session,使用响应头返回给客户端一个sessionid,浏览器获取到sessionid之后存放在本地。
第二次请求:客户端读取本地的sessionid存放在请求头中,服务器端从请求头中获取到对应的sessionid,使用sessionid在服务器本地查询对应的信息。
//默认创建一个session,默认值为true。
//设置为true情况下,客户端使用对应的sessionid查询不到的对应的session,则会创建一个新的session。如果查到则复用。
//设置为false情况下,客户端使用对应的sessionid查询不到对应的session的时候,不会创建session。
HttpSession session = request.getSession();
System.out.println("存入session信息,sessionid:" + session.getId() + ",value:" + value + ",serverPort:" + serverPort);
session.setAttribute("name", value);
session 分为sessionid和sessionvalue
session 跟 token非常相似。session、token本身是临时的,sessionid和token都是保证临时且唯一的。
服务器集群之后会出现哪些问题
1.分布式session问题(因为session存放在服务器端,sesionid找不到对应的sesion)
2.分布式任务调度平台(服务器集群之后如何保证定时job唯一性问题、幂等性)
2.1 xxl-job 框架
3.分布式锁解决方案
3.1 基于zookeeper 使用临时节点 + 事件通知
3.2 基于redis 使用setnx方式 不推荐,容易产生死锁现象,代码复杂
3.3 基于SpringCloud 的 redission。redis中提供了很多关于分布式解决方案的 分布式锁
4.分布式日志收集问题(如果有服务有20台做集群,查询日志的话非常麻烦)
4.1 elk
4.2 kafka
5.分布式事务问题(与集群没有关系)
5.1 lck 框架
6.分布式配置中心(与集群没有关系)
6.1 SpringCloud中的config
6.2 携程apollo 框架
分布式Session解决方案
方案1.直接使用cookie替代session(不靠谱)。不推荐
方案2.使用Nginx反向代理 使用IP绑定算法。不推荐,因为同一个ip只能访问指定的同一个机器访问(没有负载均衡,相当于没有做集群处理)
方案3.使用数据库。不推荐,效率低。
方案4.tomcat 内置支持对session 的同步。不推荐,同步会产生延迟。
方案5.使用Spring-session框架,相当于把我们的session值缓存到redis中。推荐使用
方案6.使用Token代替session。推荐使用
面试题:你们项目在发布的时候,如何保证Session不失效的问题?
使用spring-session框架,缓存session的值到redis中(一级缓存和二级缓存)。
分布式session一致性问题的更多相关文章
- 【Distributed】分布式Session一致性问题
一.概述 1.1 什么是Session 1.2 Session实现原理 1.3 Session常见问题 Session 保证在那里? 关闭浏览器Session会失效吗 服务器集群之后,Session产 ...
- 分布式Session一致性解决方案有哪些?
1.使用cookie代替session(不安全,不推荐使用) 2.使用数据库存储session(效率低,不推荐使用) 3.使用nginx反向代理ip绑定方法,同一个ip只能在同一台服务器上进行访问(不 ...
- 分布式session一致性
实现思路:当客户端发送请求到服务端后,在后台生成一个token,将token作为key,用户状态信息作为value,存入redis缓存中,并设置过期时间,最后把token返回给客户端 客户端第会保存t ...
- 分布式Session共享解决方案
分布式Session解决方案 Author:SimpleWu 分布式Session一致性? 说白了就是服务器集群Session共享的问题 Session的作用? Session 是客户端与服务器通讯会 ...
- 【Redis】分布式Session
一.问题引出 1.1 Session的原理 1.2 问题概述 二.解决方案 三.代码实现-使用Token代替Session 3.1 Service 3.2 TokenController 一.问题引出 ...
- 搞懂分布式技术11:分布式session解决方案与一致性hash
搞懂分布式技术11:分布式session解决方案与一致性hash session一致性架构设计实践 原创: 58沈剑 架构师之路 2017-05-18 一.缘起 什么是session? 服务器为每个用 ...
- Tornado 自定义session,与一致性哈希 ,基于redis 构建分布式 session框架
Tornado 自定义session,与一致性哈希 ,基于redis 构建分布式 session import tornado.ioloop import tornado.web from myhas ...
- 分布式下Session一致性问题
一.Session一致性问题 1.1 什么是Session 用户使用网站的服务,基本上需要浏览器和web服务器进行多次交互,web服务器如何知道哪些请求是来自哪个会话的? 具体方式为:在会话开始时,分 ...
- 分布式下Session一致性架构举例
一.问题及方案 见这篇文章:分布式下Session一致性问题 二.分布式环境搭建: 系统环境 [root@centos7 ~]# cat /etc/redhat-release CentOS Linu ...
随机推荐
- intellj idea 常用快捷键
1.command+shift+a 查找操作2.command+e 查找历史打开的文件3.command+n 查找类4.command+shift+n 查找文件
- SpringBoot/SpringMVC 下载本地文件
页面代码: <!DOCTYPE html> <html lang="utf-8"> <meta http-equiv="Content-Ty ...
- oracle-sql脚本
select * from dba_users; create tablespace kyc_coo; create user kyc_coo identified by "123456&q ...
- python连接mysql数据库(MySQL)
在介绍python在数据库中的操作之前先简单介绍点mysql中的操作语言: [root@elk-server --]# mysql -u root -p Enter password: Welcome ...
- ORA-03114: not connected to ORACLE
PlSql Developer出现这个问题的时候,只要重新连接一些数据库就行了!
- 深入理解 iptables 和 netfilter 架构
[译] 深入理解 iptables 和 netfilter 架构 Published at 2019-02-18 | Last Update 译者序 本文翻译自 2015 年的一篇英文博客 A Dee ...
- CSV文件规范及其Java解析方式
Comma-separated values(CSV)文件规范见WIKIPEDIA:https://en.wikipedia.org/wiki/Comma-separated_values#RFC_4 ...
- Grep---linux系统三剑客(一)
grep .sed.awk被称为linux中的"三剑客". grep 更适合单纯的查找或匹配文本 sed 更适合编辑匹配到的文本 awk 更适合格式化文本,对文本进行较复杂格式 ...
- Fabric1.4 背书策略 .yam文件
{ identities: [ // 以下几项自动编号为[0,1,2] { role: { name: "member", mspId: "peerOrg1" ...
- node.js基础---增删
官方API文档:http://nodejs.cn/api/fs.html#fs_fs_rmdir_path_callback 在调用node方法中同步有Sync异步没有 //文件系统 //1.引入 ...