淘宝网站,每时每刻都有过百万的用户登录退出,也是用SESSION或者COOKIE做的登录回话吗?
淘宝网站,每时每刻都有过百万的用户登录退出,也是用SESSION或者COOKIE做的登录回话吗?
回复内容:
淘宝网站,每时每刻都有过百万的用户登录退出,也是用SESSION或者COOKIE做的登录回话吗?
首先来理解一下COOKIE和SESSION。
COOKIE是目前最较为安全的在客户端存储数据的方式,这个基本没什么说的。
而SESSION本质上是一个创建出来的概念,然后在各种语言中实现了它而已。
SESSION是通过一个特定的COOKIE保存一个sessionid,然后在服务端通过这个sessionid,查询某个存储(或服务)查到对应的一段信息,由于我们可以保证这个sessionid只保存在用户的浏览器里,不会被窃取(防止了xss),也很难被伪造(最原始的就是随机生成一段比较长的随机串),所以可以用来作为用户临时身份鉴权的一个方式。
比如在PHP里,这个cookie的key是PHPSESSID,它的值是sessionid,一般是一个随机生成的字符串(如:rnlevc3m5t36kmeq3ffduab5o7),而在服务端的/tmp 目录下,有一个 /tmp/sess_rnlevc3m5t36kmeq3ffduab5o7 文件,保存了你想对这个用户保存的个人信息。
这种方式是非常低效的。主要在三个方面。
- 查询过程是读服务器文件,这个效率瓶颈可想而知
- 查询过程是读本地文件,如果有多台机器,那么就无法共享了
- rnlevc3m5t36kmeq3ffduab5o7是纯随机的,里面没有包含任何信息量
所以一般我们会借用这种思路,重新来实现SESSION
- 把SESSEION从本地文件转移到一个高可用的中心化缓存,比如memcached集群,保证数据高效访问
- 同上,一个中心化的缓存系统,这样多台机器就可以共享SESSION了
- 用一种算法来生成rnlevc3m5t36kmeq3ffduab5o7这一串东西,在里面包含一些有用的信息,比如uid、过期时间等等,服务端加密,服务端解密,在某些情况下,可以减少对中心化缓存的依赖,提高性能
是的,一般都是二者结合,格子应用在合适的应用场景
当然是cookie,推荐你去看一本书,淘宝技术的十年,里面就说了,session同步共享是很难解决的问题
你禁用cookie看看是否能登录就知道啦。
会用cookie或者SESSION,对于用户来说自己和淘宝是一对一的,这个和百万的数量级自然就没有关系。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

PHP 8.4 带来了多项新功能、安全性改进和性能改进,同时弃用和删除了大量功能。 本指南介绍了如何在 Ubuntu、Debian 或其衍生版本上安装 PHP 8.4 或升级到 PHP 8.4

CakePHP 是 PHP 的开源框架。它的目的是使应用程序的开发、部署和维护变得更加容易。 CakePHP 基于类似 MVC 的架构,功能强大且易于掌握。模型、视图和控制器 gu

登录 CakePHP 是一项非常简单的任务。您只需使用一项功能即可。您可以记录任何后台进程(如 cronjob)的错误、异常、用户活动、用户采取的操作。在 CakePHP 中记录数据很容易。提供了 log() 函数

Visual Studio Code,也称为 VS Code,是一个免费的源代码编辑器 - 或集成开发环境 (IDE) - 可用于所有主要操作系统。 VS Code 拥有针对多种编程语言的大量扩展,可以轻松编写

CakePHP 是一个开源MVC 框架。它使开发、部署和维护应用程序变得更加容易。 CakePHP 有许多库可以减少大多数常见任务的过载。
