news 2026/5/28 8:36:33

高并发下的 Token 存储策略: Redis 与 MySQL 的一致性

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
高并发下的 Token 存储策略: Redis 与 MySQL 的一致性

一、 背景:一个 Token 的两难境地

在微服务或前后端分离架构中,Access Token是用户身份的唯一凭证。关于它的存储,我们面临两个看似矛盾的需求:

  1. 极速验证:每个接口请求(QPS 可能高达数万)都要验证 Token,延迟必须在毫秒级。
  2. 数据安全与管理:Token 关系到用户安全,不能丢;管理员需要在后台查询、踢人下线,需要复杂的查询能力。

解决方案:采用“Redis (热数据) + MySQL (冷数据)”的双存储架构。


二、 核心问题 1:后端鉴权时,该读 Redis 还是 MySQL?

结论:只读 Redis,绝不读 MySQL。

当用户发起请求GET /order/list并携带Bearer Token时,后端的拦截器(Filter)执行流程如下:

  1. Redis 是“地铁闸机”

    • 拦截器直接去 Redis 查询该 Token。
    • 有数据:放行。耗时< 1ms
    • 无数据:直接拦截,返回401 Unauthorized不进行MySQL 回源查询。
  2. MySQL 是“户籍档案室”

    • MySQL 的作用不是用来给代码做实时鉴权的。
    • 如果每个请求都查 MySQL,数据库连接池瞬间就会被耗尽,整个系统会因为鉴权逻辑而崩溃。

原则:在高频的鉴权场景下,Redis 是唯一的“权威(Authority)”


三、 核心问题 2:Redis 和 MySQL 的一致性如何保持?

既然两边都存了,如何保证数据不打架?我们按 Token 的生命周期分为四个阶段来看:

1. 登录阶段(创建:双写)

当用户登录成功生成 Token 时:

  • 动作 A:将 Token 信息插入MySQL(作为持久化备份,供管理员查询)。
  • 动作 B:将 Token 信息写入Redis,并设置TTL (过期时间)(如 30 分钟)。
  • 一致性评价:强一致。

2. 鉴权阶段(读取:Redis 主导)

  • 动作:只读 Redis。
  • 异常情况:如果 Redis 数据丢了(如宕机)但 MySQL 还在,怎么办?
  • 策略认栽。系统视作用户“未登录”,前端会触发刷新 Token 或重新登录流程。绝不回源查 DB,防止缓存击穿导致数据库雪崩。

3. 过期阶段(自然消亡:最终不一致)

  • 动作
    • Redis:TTL 一到,自动删除 Key。用户访问报 401。
    • MySQL:数据依然存在,变成了“历史垃圾数据”。
  • 策略允许不一致。这种不一致对业务无害(因为鉴权只看 Redis),MySQL 的历史数据可以通过定时任务清理。

4. 登出/踢人阶段(销毁:双删)

这是最关键的一步,必须保证安全。

  • 动作显式删除 MySQL+显式删除 Redis
  • 顺序建议删 DB->删 Redis(符合 Cache Aside Pattern)。
  • 策略:必须确保 Redis 被删掉,否则用户在 Token 过期前还能非法访问。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/28 2:38:52

中国辅助驾驶“新竞赛”打响,高智价比AI芯片如何定义新标杆?

中国辅助驾驶的落地竞速已经从单纯的性能比拼&#xff0c;进入“法规与体验双轮驱动”的全新阶段。一方面&#xff0c;包括中国在内的全球多个国家和地区已对车辆搭载AEB系统提出强制性要求&#xff0c;直接推动了组合辅助驾驶进入市场主导的“爆发期”。根据《高工智能汽车研究…

作者头像 李华
网站建设 2026/5/25 12:02:02

渔人的直感:FF14终极智能钓鱼计时器完全指南

渔人的直感&#xff1a;FF14终极智能钓鱼计时器完全指南 【免费下载链接】Fishers-Intuition 渔人的直感&#xff0c;最终幻想14钓鱼计时器 项目地址: https://gitcode.com/gh_mirrors/fi/Fishers-Intuition 还在为错过幻海流最佳时机而烦恼吗&#xff1f;是否经常因为分…

作者头像 李华
网站建设 2026/5/25 14:31:56

如何在30天内完成Agent有效性验证?生物药研发加速的秘密武器

第一章&#xff1a;生物制药Agent有效性验证的挑战与机遇在生物制药领域&#xff0c;智能Agent正逐步应用于药物发现、靶点识别和临床试验模拟等关键环节。然而&#xff0c;这些Agent的有效性验证面临诸多挑战&#xff0c;同时也孕育着重大技术突破的机遇。数据异质性与标准化难…

作者头像 李华
网站建设 2026/5/20 10:33:28

为什么顶尖金融机构都在重构Agent审计日志?背后隐藏的4大合规趋势

第一章&#xff1a;金融合规 Agent 的审计日志在金融行业&#xff0c;系统操作的可追溯性是合规性的核心要求之一。审计日志作为记录系统行为的关键组件&#xff0c;为监管审查、异常检测和责任追溯提供了数据基础。金融合规 Agent 通过自动化手段收集、分析并归档关键操作事件…

作者头像 李华
网站建设 2026/5/26 2:10:23

58、Linux与Ubuntu:深入解析与使用指南

Linux与Ubuntu:深入解析与使用指南 1. mkinitrd工具介绍 mkinitrd工具会查看 /etc/fstab 、 /etc/modprobe.conf 和 /etc/raidtab 文件,以获取在启动过程中确定需要加载哪些模块所需的信息。在我们的系统中,使用以下命令: # mkinitrd initrd-2.6.7-1.img 2.6.7-1…

作者头像 李华
网站建设 2026/5/27 15:14:09

60、Ubuntu安装规划与硬件要求全解析

Ubuntu安装规划与硬件要求全解析 1. 选择Ubuntu的优势与安装关键因素 Ubuntu作为一种计算解决方案有诸多优势,由于其丰富的软件资源,它能在不同层级和硬件平台上扮演多种角色。为确保安装成功,需关注以下关键因素: - 准备工作 :充分讨论迁移或部署事宜,明确其带来的…

作者头像 李华