pai 的redis存储

11.17

Redis 存储的数据类型和用途

1.JWT Token 管理 (TokenCacheService.java:28-32)

  • jwt:valid:{tokenId} - 有效token信息 (Hash, TTL动态)
  • jwt:user:{userId}:tokens - 用户token集合 (Set, TTL动态)
  • jwt:refresh:{refreshTokenId} - 刷新token信息 (Hash, TTL动态)
  • jwt:blacklist:{tokenId} - token黑名单 (String, TTL动态)

2.用户会话管理 (RedisRepository.java:25,38 & ChatHandler.java:226,230)

  • user:{userId}:current_conversation - 用户当前会话ID (String, TTL 7天)
  • conversation:{conversationId} - 会话历史记录 (JSON String, TTL 7天)

3.组织权限缓存 (OrgTagCacheService.java:29-31)

  • user:org_tags:{username} - 用户组织标签列表 (List, TTL 24小时)
  • user:primary_org:{username} - 用户主组织 (String, TTL 24小时)
  • user:effective_org_tags:{username} - 用户有效标签权限 (List, TTL 24小时)

4.文件上传分片追踪 (UploadService.java:347,373)

  • file_upload_progress:{fileIdentifier} - 文件上传进度位图 (BitMap)
    • 使用 Redis Bitmap 追踪每个分块的上传状态
    • 每个bit代表一个chunk是否已上传

5.Redis 配置

  • 连接: localhost:6379 (application.yml:17-20)
  • 序列化: Key使用StringRedisSerializer, Value使用GenericJackson2JsonRedisSerializer (RedisConfig.java:17-18)

主要用途总结

复制代码
1. **认证授权 - JWT token状态管理、黑名单机制**
2. **会话管理 - 聊天会话持久化、用户会话追踪**
3. **权限缓存 - 多租户组织标签缓存、权限验证优化**
4. **文件处理 - 大文件分片上传状态追踪**
5. **性能优化 - 减少数据库查询、提升响应速度**

所有数据都设置了合理的TTL过期时间,确保Redis内存使用的可持续性。

相关推荐
聆风吟º1 小时前
Oracle到KingbaseES数据库迁移:全流程实战指南与避坑总结
数据库·oracle·数据库迁移·kingbasees
哈__1 小时前
Oracle至KingbaseES数据库迁移全攻略:痛点拆解、配置实操与问题排查
数据库·oracle
JZC_xiaozhong2 小时前
电商ERP如何同步订单数据到MySQL?集成方案解析
数据库·mysql·数据分析·etl工程师·嵌入式实时数据库·电商erp集成·数据集成与应用集成
消失的旧时光-19432 小时前
第四篇(实战): 订单表索引设计实战:从慢 SQL 到毫秒级
java·数据库·sql
知识分享小能手2 小时前
Oracle 19c入门学习教程,从入门到精通, Oracle 表空间与数据文件管理详解(9)
数据库·学习·oracle
zhengfei6113 小时前
Chroma DB — 未经授权的信息披露
数据库
KaiwuDB3 小时前
KaiwuDB 获评“2025 中国大数据产业年度国产化优秀代表厂商”
数据库
百***07453 小时前
一步API+Gemini 3.0 Pro进阶实战:多模态开发、性能调优与项目落地
数据库·microsoft
不想写bug呀3 小时前
Redis主从复制介绍
数据库·redis
颜颜yan_3 小时前
Oracle 迁移到 KingbaseES 实战:从评估到追平的一套可落地流程
数据库·oracle