开发者社区> sea-boat> 正文

客户端状态的存储空间——Session

简介: http协议在设计之初被设计成无状态特性,客户端的每次请求在服务端看来都是独立且无任何相关性,同一个客户端第一次请求不会与第二次请求有任何关联,即使相隔时间很短。
+关注继续查看

http协议在设计之初被设计成无状态特性,客户端的每次请求在服务端看来都是独立且无任何相关性,同一个客户端第一次请求不会与第二次请求有任何关联,即使相隔时间很短。无状态的特性让请求变得很快速且服务器也更加高效,但是随着人们对浏览器功能要求的不断提高,由于无状态导致的不足更加明显,因为有些场景下本次处理需要用到之前的请求的一些信息,如果单纯靠http协议而没有额外的机制是无法办到的。

为了提供一种让一定时间内的每次请求都拥有记忆的会话机制,需要依靠http协议的基础上提供一种解决方案,当然由于涉及到相关信息的存储,所以需要在http协议外另外提供存储介质,通信的主体无非就是客户端和服务端,于是人们可以想到的就是借客户端或服务端存储状态信息,后来基于这两端的存储的方式都被支持。在客户端,一种叫做cookie的小文本被生成并存放在客户端的指定目录,每次请求时浏览器会从cookie找出此次请求服务器希望得到的一些状态并附加到http协议头部传往服务端,服务端由此实现通信的状态性;在服务端,有时需要保存的信息量很大,存放在客户端会导致一个问题,即每次客户端请求都要携带大量的信息到服务端,传输效率低下,这时如果把客户端的信息都放在服务端就能避免大量附加信息的传输,仅仅只要携带一个识别编号到服务端即可,服务端根据此编号找到此客户端对应的保存信息,至此实现通信的状态性。

所以两种方式可以用下图表示,上面的为客户端模式,客户端每次请求都会将本地保存的状态一起传到服务端,服务端通过这些状态便可以辨别哪个客户端的某些状态。而下面的图则是服务端模式,这时客户端要传的仅仅是一个id编号,它其实是客户端的身份标识,而其他状态变量保存在服务端,通过客户端id可以找到对应客户端的状态变量,所有客户端的状态被统一存放在服务端进行管理。

 

 

 

点击订购作者《Tomcat内核设计剖析》 


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
MySql状态查看方法 MySql如何查看连接数和状态?
原文:MySql状态查看方法 MySql如何查看连接数和状态? 如果是root帐号,你能看到所有用户的当前连接。如果是其它普通帐号,只能看到自己占用的连接  怎么进入mysql命令行呢? mysql的安装目录下面有个bin目录,先用命令行进入该目录,然后用 mysql -uroot -p123456 来登录(注意:用户名和密码不用包含“”)  命令: show processlist; 如果是root帐号,你能看到所有用户的当前连接。
922 0
Flink状态管理和容错机制介绍
本文来自2018年8月11日在北京举行的 Flink Meetup会议,分享来自于施晓罡,目前在阿里大数据团队部从事Blink方面的研发,现在主要负责Blink状态管理和容错相关技术的研发
1168 0
JS获取客户端系统当前时区
function getClientTimezone(){ var oDate = new Date(); var nTimezone = -oDate.getTimezoneOffset() / 60; return nTimezone.
1843 0
对于已经添加引用,还找不到类型或名字空间的错误及svn客户端清除用户帐号密码
1 已经添加过引用,却找不到类型或名字空间。 可以看下项目的的.net framework版本是否一致。 项目(例如类库项目)右键(vs解决方案资源管理器)——》属性——》应用程序——》目标框架。 也就是检查一下引用项目与被引用项目的目标框架是否版本一致。
700 0
State Processor API:如何读取,写入和修改 Flink 应用程序的状态
Apache Flink 1.9.0引入了状态处理器(`State Processor`)API,它是基于DataSet API的强大扩展,允许读取,写入和修改Flink的保存点和检查点(checkpoint)中的状态。
1624 0
获取当前user的Session状态
select p.pid, s.sid, s.serial#,s.PROGRAM  from sys.v_$session s, sys.v_$process p where s.sid = (select sid from sys.
500 0
+关注
sea-boat
擅长篮球、跑步、游泳、羽毛球、编程、看书、写书的顾家好男人! Java深度、大数据、中间件、搜索引擎、机器学习、深度学习、Python、C++、开源! 《Tomcat内核设计剖析》作者。
276
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载