博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
仿牛客社区项目2.3登录模块——会话管理Cookie、Session
阅读量:2056 次
发布时间:2019-04-28

本文共 772 字,大约阅读时间需要 2 分钟。

HTTP无状态有会话、Cookie、Session

在这里插入图片描述

HTTP是无状态有会话的

  1. 同一个连接,服务器不记得浏览器的状态,每次请求是独立的,所以“无状态”。
  2. 为了业务连续性,引入Cookie状态管理,即有会话Cookie。
  3. Cookie缺点是不安全,cookie要存到浏览器中;总是把数据发给服务器,每次访问服务器会增加数据量,对流量和性能上有影响
  4. Session服务端对象,是JavaEE标准,存在服务端安全;也会增加服务端内存压力。
  5. 如果隐私,用Session存比较好

Cookie

在这里插入图片描述

在这里插入图片描述

浏览器 <- 服务器

响应Headers中有Cookie
在这里插入图片描述

浏览器 -> 服务器

请求Headers中有 Cookie
在这里插入图片描述

Session

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

分布式服务器

尽量用Cookie,需要用的时候再用,不用Session是为了减少服务端压力,服务器分布式部署用Session少。因为第二次请求给另一个服务器,要重新创建Session。

解决:

  1. 粘性session:同一台浏览器同一个IP给同一个服务器,但是导致负载不均衡。
  2. 同步session:同步给其他服务器,每个服务器都存了这个浏览器的session。问题:同步对服务器性能产生影响;服务器之间关联存在耦合,对部署有影响。
  3. 共享session:session专给一个服务器,其他服务器向这台服务器获取session。问题:单体服务器,如果这台服务器挂了,影响很大。如果搞集群,就和之前一样了。在这里插入图片描述
  4. 主流方法:客户端数据不存到session里,尽量存到cookie里,如果有敏感数据,就存到数据库里,数据库集群补充备份,他们之间同步数据。所有的服务器都可以访问数据库集群。问题:传统关系型数据库是存到硬盘里,访问数据和内存中读数据比,更慢,并发量大时有瓶颈,不如存到内存中好。目前有NoSQL数据库,所以存到Redis数据库更好
    在这里插入图片描述

转载地址:http://zsnlf.baihongyu.com/

你可能感兴趣的文章
iOS MapKit导航及地理转码辅助类
查看>>
检测iOS的网络可用性并打开网络设置
查看>>
简单封装FMDB操作sqlite的模板
查看>>
iOS开发中Instruments的用法
查看>>
iOS常用宏定义
查看>>
被废弃的dispatch_get_current_queue
查看>>
什么是ActiveRecord
查看>>
有道词典for mac在Mac OS X 10.9不能取词
查看>>
关于“团队建设”的反思
查看>>
利用jekyll在github中搭建博客
查看>>
Windows7中IIS简单安装与配置(详细图解)
查看>>
linux基本命令
查看>>
BlockQueue 生产消费 不需要判断阻塞唤醒条件
查看>>
ExecutorService 线程池 newFixedThreadPool newSingleThreadExecutor newCachedThreadPool
查看>>
强引用 软引用 弱引用 虚引用
查看>>
数据类型 java转换
查看>>
"NetworkError: 400 Bad Request - http://172.16.47.117:8088/rhip/**/####t/approval?date=976
查看>>
mybatis 根据 数据库表 自动生成 实体
查看>>
win10将IE11兼容ie10
查看>>
checkbox设置字体颜色
查看>>